gpt4 book ai didi

php - 当 WHERE 中使用变量时限制 mysql 查询的输出

转载 作者:行者123 更新时间:2023-11-29 08:48:11 25 4
gpt4 key购买 nike

我有一个 mysql 语句,用于查询数据库中的最新轨道。然而,由于数据库已部分规范化,ID 位于不同的表中。在查询中,我从艺术家表中获取艺术家 ID,并将它们放入变量中。然后,该变量被解析为一个查询,该查询查看轨道以找到最新的轨道,这就是问题所在。由于 $artist 变量可以包含大量 ID,因此所有这些 ID 都会解析到查询中,结果是几个 url 组合在一起,即使我在查询上设置了 LIMIT。

请记住,我无法限制艺术家查询,因为我需要从表中获取所有艺术家并从所有艺术家中找到最新轨道。

如何在不限制艺术家查询的情况下从查询中获取最新的网址?

//Set up artist query so only NBS artists are chose

$findartist = mysql_query("SELECT * FROM artists") or die(mysql_error());
while ($artist = mysql_fetch_array($findartist)){

$artist = $artist['ID'];

//get track url
$fetchurl = mysql_query("SELECT * FROM tracks WHERE id = '$artist' ORDER BY timestamp DESC LIMIT 1");

url = mysql_fetch_array($fetchurl);
$track_ID = $url ['ID'];
$trackname = $url ['name'];
$trackurl = $url ['url'];
$artist_ID =$url['ID'];

}

添加:

 $findartist = mysql_query("SELECT A.*, T.*
FROM (
SELECT T.ARTIST_ID, MIN(T.TRACK_ID) TRACK_ID
FROM (
SELECT ARTIST_ID, MAX(`TIMESTAMP`) `TIMESTAMP`
FROM TRACKS
GROUP BY ARTIST_ID
) L
JOIN TRACKS T ON ( L.ARTIST_ID = T.ARTIST_ID
AND L.`TIMESTAMP` = T.`TIMESTAMP`)
GROUP BY T.ARTIST_ID
) X
JOIN ARTISTS A ON X.ARTIST_ID = A.ARTIST_ID
JOIN TRACKS T ON (X.TRACK_ID = T.TRACK_ID AND X.ARTIST_ID = T.ARTIST_ID)
ORDER BY A.NAME");



while ($artist = mysql_fetch_array($findartist)){

$artist = $artist['ID'];
$trackurl = $artist['url'];

最佳答案

artists表和tracks表之间的关系是one-to-many 。因此,您的 tracks 表应该有一列 artist_idforeign key constraint它将此列与artists 表中的id 列交叉引用。完成此操作后,获取最新轨道的查询将如下所示:

SELECT id, name, url, MAX(timestamp) timestamp
FROM tracks
GROUP BY artist_id

关于php - 当 WHERE 中使用变量时限制 mysql 查询的输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12019199/

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