这是我连接在一起的两个表。。。
song_id song_name
51 | Song Name A
368 | Song Name B
168 | Song Name C
568 | Song Name D
13 | Song Name E
song_id | song_order| show_date |show_id
368 | 1 | 2010-02-17 00:00:00 | 367
368 | 0 | 2012-04-06 00:00:00 | 499
51 | 2 | 2012-01-19 00:00:00 | 399
51 | 2 | 2013-04-24 00:00:00 | 870
51 | 8 | 2013-07-19 00:00:00 | 899
368 | 2 | 2013-07-19 00:00:00 | 899
13 | 5 | 2013-07-19 00:00:00 | 899
568 | 2 | 2013-07-19 00:00:00 | 899
368 | 4 | 2012-06-08 00:00:00 | 799
168 | 2 | 2013-06-28 00:00:00 | 896
568 | 2 | 2013-07-03 00:00:00 | 897
568 | 2 | 2010-02-21 00:00:00 | 897
我已经想好了在SQL Fiddle链接上要做什么,但我无法获得正确的代码。我试图根据show_id的值,比如它的"899",返回等于899的所有行,show_id都有相同的日期分配给它们,但根据歌曲id,我想返回song_id出现的前一个日期。
我希望返回数据。。。
SHOW_DATE | SHOW_ID | SONG_NAME | SONG_ID | PREVDATE
July, 19 2013 | 899 | Song Name A | 51 | April, 24 2013
July, 19 2013 | 899 | Song Name B | 368 | April, 08 2012
July, 19 2013 | 899 | Song Name E | 13 | FIRST TIME
July, 19 2013 | 899 | Song Name D | 568 | July, 03 2013
我在这里的代码只是返回2013年7月19日之前的前一个日期,也就是2013年3月3日,并将其用于每个PrevDate。有人能帮我吗?我不是最有经验的程序员,我相信我不能做我在这里做的事情,因为我正在分组一个子查询。提前感谢!
SELECT tbl_shows.show_date, tbl_shows.show_id,
tbl_songs.song_name, tbl_shows.song_id, (
SELECT
MAX(show_date)
FROM tbl_shows AS fdate
WHERE tbl_shows.show_date > show_date
) As PrevDate
FROM tbl_shows LEFT JOIN tbl_songs
ON tbl_shows.song_id = tbl_songs.song_id
WHERE tbl_shows.show_id = 899
看起来您只需要告诉MySQL按日期对结果进行分组:
SELECT tbl_shows.show_date, tbl_shows.show_id,
tbl_songs.song_name, tbl_shows.song_id, (
SELECT
MAX(show_date)
FROM tbl_shows AS fdate
WHERE tbl_shows.show_date > show_date
) As PrevDate
FROM tbl_shows LEFT JOIN tbl_songs
ON tbl_shows.song_id = tbl_songs.song_id
GROUP BY tbl_shows.show_date
HAVING tbl_shows.show_id = 899
编辑:或者,正如Dan Bracuk所指出的,你可以这样做:
SELECT tbl_shows.show_date, tbl_shows.show_id,
tbl_songs.song_name, tbl_shows.song_id, (
SELECT
MAX(show_date)
FROM tbl_shows AS fdate
WHERE tbl_shows.show_date > show_date
) As PrevDate
FROM tbl_shows
LEFT JOIN tbl_songs
ON tbl_shows.song_id = tbl_songs.song_id
WHERE tbl_shows.show_id = 899
GROUP BY tbl_shows.show_date
ORDER BY tbl_shows.show_id DESC
LIMIT 0, 10
注意:最后两行更像是一个例子。
试试这个。。。
SELECT a.show_date, a.show_id,
b.song_name, a.song_id, (
SELECT
MAX(show_date)
FROM tbl_shows AS c
WHERE a.show_date > c.show_date and a.song_id = c.song_id
) As PrevDate
FROM tbl_shows a, tbl_songs b
WHERE a.song_id = b.song_id
AND a.show_id = 899