首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >PHP MySQL join两个表查询

PHP MySQL join两个表查询
EN

Stack Overflow用户
提问于 2018-06-24 01:38:13
回答 2查看 69关注 0票数 0

我有两个表,即摘要表和具有一对多关系的作者,对于while循环上的每个迭代,我希望显示来自抽象表的唯一数据行的html表与来自作者表的相应行。

这是我所做的:

代码语言:javascript
复制
public function getAll() {
    try {
          $sql = "  SELECT tbl_abstract.abstract_id, tbl_abstract.first_name,
                            tbl_abstract.last_name,tbl_abstract.content,        
                            tbl_author.afirst_name, tbl_author.alast_name, 
                            tbl_author.aaffilition 
                    FROM tbl_abstract  
                        INNER JOIN tbl_author ON  tbl_abstract.abstract_id = tbl_author.abstract_id 
                    GROUP BY tbl_abstract.abstract_id";

          $stmt= $this->pdo->prepare($sql);
          $stmt->execute();
          $count =  $stmt ->rowCount();
          while($row = $stmt->fetch(PDO::FETCH_ASSOC)){
          ?>

             <table class="table" >
              <tr>
                <td  align="center" >
                   //data from tbl_abstract
                   <?php echo $row["abstract_id"];  ?>. <?php print($row["abstract_title"]); ?>
                    <?php echo $row["first_name"].'&nbsp;'.$row["last_name"]; ?>,

                    //data from tbl_author
                    <?php echo $row["afirst_name"].'&nbsp;'.$row["alast_name"];?>         
                </td>  
              </tr>
              <tr>
                <td align="center" ">
                   //data from tbl_abstract
                   <?php print($row["content"]); ?>
                </td>
              </tr>

            </table>
          <?php 
         }          
    }catch(PDOException $e){
       echo $e->getMessage(); 
       return false;
    }  
}

tbl_author中有三条记录与tbl_abstract中的abstract_id相关联,但我只获得了一条记录,而不是them.Please帮助中的三条

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-06-24 05:12:38

试试这个:-

代码语言:javascript
复制
<?php

$sql = "SELECT * 
        FROM tbl_abstract
        where abstract_id IN (SELECT distinct abstract_id
                              FROM tbl_abstract)";

      $stmt= $this->pdo->prepare($sql);
      $stmt->execute();
      $count =  $stmt ->rowCount();
?>
      <table class="table" >
      while($row = $stmt->fetch(PDO::FETCH_ASSOC)){
      ?>
          <tr>
            <td  align="center" >
               //data from tbl_abstract
               <?php echo $row["abstract_id"];  ?> <?php print($row["abstract_title"]); ?>
                <?php echo $row["first_name"].'&nbsp;'.$row["last_name"]; ?>,
         <?php          
         $sql1 = "SELECT *
                  FROM tbl_author
                  WHERE abstract_id = '".$row["abstract_id"]."'" ;
         $stmt1= $this->pdo->prepare($sql1);
         $stmt1->execute();
         while($row1 = $stmt1->fetch(PDO::FETCH_ASSOC)){
                //data from tbl_author
                echo $row1["afirst_name"].'&nbsp;'.$row1["alast_name"];
         } ?>         
            </td>
            <td align="center">
               //data from tbl_abstract
               <?php print($row["content"]); ?>
            </td>
          </tr>
       <?php } ?>

        </table>
票数 0
EN

Stack Overflow用户

发布于 2018-06-24 01:46:34

尝试删除GROUP BY子句,如下所示:

代码语言:javascript
复制
SELECT 
    tbl_abstract.abstract_id, tbl_abstract.first_name, 
    tbl_abstract.last_name,tbl_abstract.content, tbl_author.afirst_name, 
    tbl_author.alast_name, tbl_author.aaffilition 
FROM 
    tbl_abstract  
INNER JOIN 
    tbl_author ON  tbl_abstract.abstract_id = tbl_author.abstract_id

Group by是按字段abstract_id对所有作者进行分组,这意味着它不会返回所有作者,而是只返回一个abstract_id (基于排序字段,在本例中它可能是主键,因为它没有显式定义)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51003585

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档