PHP MySQL объединяет две таблицы запроса - PullRequest
0 голосов
/ 23 июня 2018

У меня есть две таблицы, т.е. абстрактная таблица и автор с отношением один ко многим, для каждой итерации цикла while я хочу отобразить HTML-таблицу уникальных строк данных из абстрактной таблицы с соответствующими строками из таблицы авторов.

Вот что я сделал:

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, связанные с abstract_id из tbl_abstract, но я получаю только одну запись вместо 3 из них. Пожалуйста, помогите

Ответы [ 2 ]

0 голосов
/ 24 июня 2018

Попробуйте это: -

<?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 голосов
/ 23 июня 2018

Попробуйте удалить предложение GROUP BY следующим образом:

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

Группировать по - группировать всех авторов по полю abstract_id, что означает, что он не вернет всех авторов, кроме одного.для одного abstract_id (на основе поля сортировки, которое в данном случае, вероятно, является первичным ключом, потому что оно не определено явно) ..

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...