SQL从另一行匹配查询中查找上一个日期


SQL Finding the previous date from another row matching query

这是我连接在一起的两个表。。。

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