gpt4 book ai didi

php - 在 MySQL LEFT JOIN 显示问题中需要帮助

转载 作者:太空宇宙 更新时间:2023-11-03 11:13:13 25 4
gpt4 key购买 nike

我正在尝试在网页上正确显示 MySQL 查询。

我有 4 个连接在一起的简单表格

歌手:singer_id, singer_name

歌曲 : singer_id, song_name, album_id

专辑 : singer_id, album_id, album_name

我已经设法使用此查询获取这些表。

SELECT singers.singer_name, songs.song_name, albums.album_name

FROM singers
LEFT JOIN songs ON singers.singer_id = songs.singer_id
LEFT JOIN albums ON albums.album_id = songs.album_id
WHERE singers.singer_id = ?
ORDER BY songs.song_id DESC

我现在遇到的问题是我似乎无法正确显示这些表格。

假设我有一位歌手,有 1 张专辑和 11 首歌曲。这是我为这位歌手得到的结果。

singer_name  |     song_name     |     album_name
__________________________________________________

singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name
singer name | song name | album name

所以我得到的不是 1 张专辑,而是 11 次相同的专辑。

在网页上,我使用 foreach() 显示相册我得到的是同一张专辑,而不仅仅是一张专辑。

现在开始提问....

我怎样才能只显示相册 3 次?

(无需硬编码,因为我可能还有一位拥有 9 张专辑的歌手)。

在此先感谢您的帮助。

编辑:

这是我显示歌曲的方式

                        <?php foreach($results as $song): ?>
<tr>
<td></td>
<td>
<a href="/song/<?php echo urlencode($song['song_url']); ?>/" class="song">
<span><?php echo $song['song_name']; ?></span>
</a>
</td>
<td>
<a href="/album/<?php echo urlencode($song['album_name']); ?>/" class="album">
<?php echo $song['album_name']; ?>
</a>
</td>
<td>
<span class="time">
<?php echo $song['song_time']; ?>
</span>
</td>
<td>
<a href="/search/?search=<?php echo urlencode($song['song_genre']); ?>" class="genre">
<?php echo $song['song_genre']; ?>
</a>
</td>
<td><a href="#" class="play">נגן</a></td>
</tr>
<?php endforeach; ?>

即使歌曲未附加到任何专辑,我也会获得所有歌曲。正是我想要的。

显示相册的问题:

                    <?php foreach($results as $album): ?>
<li>
<a href="/album/<?php echo urlencode($album['url']); ?>/" class="album">
<img src="/media/<?php echo $album['singer_dir'] . '/' . $album['album_thumb']; ?>" alt="" />
<span class="album_name"><?php echo $album['album_name']; ?></span>
</a>
</li>
<?php endforeach; ?>

这位歌手有 1 张专辑,但我得到了 11 次。我不是因为这张专辑有 11 首歌。我只需要显示一次....

最佳答案

在不太了解 $result 变量(例如,它可能是 PDO 对象或数组,我不知道)的情况下,我的回答必须是一个 hackish:

<?php foreach($results as $album): ?>
<li>
<a href="/album/<?php echo urlencode($album['url']); ?>/" class="album">
<img src="/media/<?php echo $album['singer_dir'] . '/' . $album['album_thumb']; ?>" alt="" />
<span class="album_name"><?php echo $album['album_name']; ?></span>
</a>
</li>
<?php break; ?>
<?php endforeach; ?>

就我个人而言,我不会在我自己的代码中这样做,但如果没有更全面的代码图和更清晰的想法,那就是它就是这样。


编辑 1:

如果是这种情况,那么您只需要以下内容。 foreach 是不必要的:

<li>
<a href="/album/<?php echo urlencode($result[0]['url']); ?>/" class="album">
<img src="/media/<?php echo $result[0]['singer_dir'] . '/' . $result[0]['album_thumb']; ?>" alt="" />
<span class="album_name"><?php echo $result[0]['album_name']; ?></span>
</a>
</li>

编辑 2:

SELECT album_name
FROM albums
WHERE singer_id = ?

并使用 foreach 遍历此结果集。

关于php - 在 MySQL LEFT JOIN 显示问题中需要帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7053158/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com