如何在PHP中处理一对多关系

时间:2016-02-23 17:24:56

标签: php mysql join

如何正确回显一对多查询结果?

使用一个表查询结果,我只需在获取后回显每一行,例如:

+---+------+
|ID | title|
|1  | a    |
|2  | b    |
|3  | c    |
+---+------+

$smtp->bind_result($ID, $title);
while($smtp->fetch()) {
    \\echo here                        
}

但是在使用自然连接的查询(下面的例子)之后,我不知道如何在PHP中回应它:
&#34; 3 - c - 动作,幻想,军事&#34; < / p>

+----+-------+----------+
| ID | title | genre    |
|  3 |   c   | Action   |
|  3 |   c   | Fantasy  |
|  3 |   c   | Military |
+----+-------+----------+

编辑:

让我重新解释一下这个问题。当使用一对多的关系时,我如何正确地展示来自&#34;很多&#34;的结果?表

这是我目前使用的代码。

//connect to database with self made db class object.
$db = new db();
$db = $db->connect();

$smtp = $db->prepare('select ID, title, description, genre from movie NATURAL JOIN movie_genres WHERE date >= ? AND date < ?');
$smtp->bind_param('ss', $seasonStart, $seasonEnd); //variables defined based on current date.
$smtp->execute();
$smtp->bind_result($ID, $title,$description, $genre));
while($smtp->fetch()) {
    echo '
    <div class="upcoming">
        <div id="upcomingPoster" style="background-image: url(images/' . $ID . '.jpeg)">
            <div>
                <a href="">' . $title . '</a>
            </div>
        </div>
        <div class="upcomingInfo">
            <h2>Description</h2>
            <p class="upcomingInfoDescription">' . $description .'</p>
            <div></div>
            <p>' . $genre . '</p>
        </div>
    </div>';
}

现在使用它时,我的代码基本上为每一行循环。但我试图将所有类型放在彼此旁边,然后再循环到下一部电影。

2 个答案:

答案 0 :(得分:0)

$stmt->bind_result($ID, $title, $genre);
$movies = array();
while($stmt->fetch()) {
    if (!isset($movies[$ID])){
        $movies[$ID] = array('title'=>$title, 'genres'=>array());
    }
    $movies[$ID]['genres'][] = $genre;
}
foreach ($movies as $ID=>$movie){
    echo $ID . ' - ' . $movie['title'] . ' - ';
    $first = true;
    foreach ($movie['genres'] as $genre){
        if (!first) echo ', ';
        $first = false;
        echo $genre;
    }
    echo '<br />';
}

答案 1 :(得分:-1)

我不确定你要做什么,如果我理解的是你想要问的话。

我认为您正在使用PHP-PDO,因此有必要将sql-statement上的fetch结果存储到另一个变量中。这看起来像这样:

$smtp->bind_result($ID, $title);
while($result = $smtp->fetch()) {
  var_dump($result);
}

所以现在你应该看到获取行的数据。