作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 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_id
和 foreign 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/
我是一名优秀的程序员,十分优秀!