0

我是 PHP 新手,我只是无法弄清楚我的代码。我正在使用 MySQL 和 PHP。

表:人 PK:personID 其他字段:lastName、firstName、hireDate、imgName

表:validMajors PK:majorAbbrev 其他字段:majorDesc

(Junction) 表:personMajors personID、majorAbbrev

当我运行我的代码(使用NATURAL JOIN)时,它将显示图像、姓氏和名字以及雇用日期。太棒了!但我也需要它来显示他们的专业(我希望显示majorAbbrev)。它也不会显示在 person 表中但不在 personMajors 表中的人,这是一个问题,因为我们在 person 表中有工作人员(他们没有专业,因为他们不是学生)

这是我的代码:

<table align="center">
    <?php
        $connection = mysqli_connect(DBHOST, DBUSER, DBPASS, DBNAME);

        if ( mysqli_connect_errno() ) {
           die( mysqli_connect_error() );  
        }
        $sql = "SELECT * FROM person NATURAL JOIN personMajors ORDER BY lastName";

        if ($result = mysqli_query($connection, $sql)) {     
           // loop through the data

           $columns=4;
           $i = 0;
            while($row = mysqli_fetch_assoc($result))
            {

            if($i % $columns ==0){


                 echo "<tr>";
                 }

                 echo "<td class='staffImage badgeText frameImage displayInLine'>" . "<img src='images/staff/".$row['imgName'].".jpg'>". "<br>". 
                                                            "<strong>" . $row['firstName'] . "</strong>" ." ". 
                                                            "<strong>" . $row['lastName'] . "</strong>" . "<br>" .
                                                            "Hire Date: ".$row['hireDate'] ."</td>";
                                                            "Major: " .$row['majorAbbrev'] ."</td>";     //Does not display

if($i % $columns == ($columns - 1)){
                 echo "</tr>";               
            }

            $i++;
            }
            // release the memory used by the result set
            mysqli_free_result($result); 
        } 
        // close the database connection
        mysqli_close($connection); 
    ?>
    </table>

任何想法/解决方案将不胜感激!

4

2 回答 2

2

因为你没有正确连接你的 php。您在显示 后结束 ( ;) 您的。echo$row["lastName"]

您可以尝试这些来加入三个表:

SELECT * FROM person
       LEFT JOIN personMajors ON person.personID = personMajors.personID
       LEFT JOIN validMajors ON personMajors.majorAbbrev = validMajors.majorAbbrev

或者您可以定义在查询中调用哪些列:

SELECT person.personID,
       person.lastName,
       person.firstName,
       person.hireDate,
       person.imgName,
       validMajors.majorAbbrev,
       validMajors.majorDesc
FROM person
       LEFT JOIN personMajors ON person.personID = personMajors.personID
       LEFT JOIN validMajors ON personMajors.majorAbbrev = validMajors.majorAbbrev

然后你可以用你现在调用的方式调用结果(更简洁的版本):

echo '<td class="staffImage badgeText frameImage displayInLine">
          <img src="images/staff/'.$row["imgName"].'.jpg"><br>
          <strong>'.$row["firstName"].'</strong>
          <strong>'.$row["lastName"].'</strong><br>
          Hire Date: '.$row["hireDate"].'
          Major: '.$row["majorAbbrev"].'
      </td>';
于 2016-04-06T01:39:57.520 回答
1

(二试):人与主要关系是一对一还是一对多?

好的,这个 SELECT 语句应该可以工作:

SELECT person.*, validMajors.* FROM person AS p, validMajors AS vm,   personMajors AS pm WHERE p.personID = pm.personID AND pm.majorAbbrev = vm.majorAbbrev 
于 2016-04-06T01:39:41.287 回答