如何在Mysql中的2条记录中选择最后一个日期

时间:2012-07-31 04:01:35

标签: mysql

如何在Mysql的2条记录中选择最后一个日期?

表A

SID NAME Sex
1  Jam  M
2  Da   F

表B

 ID Title SID Date
   1  A     1   2012-07-31 09:57:10
   2  NULL  1   2012-07-31 09:57:13
   3  A     2   2012-07-31 10:10:13
   4  NULL  2   2012-07-31 10:57:13

我想内连接这两个表,

但只选择表B中的一个记录(不同于SID),其中title不为null,然后显示

最大标题日期为空字段。

结果需要最大的Date of null标题:

ID Name Title SID  Date
1  Jam  A     1    **2012-07-31 09:57:13**
2  DA   A     2    **2012-07-31 10:57:13**

怎么做?

3 个答案:

答案 0 :(得分:0)

我认为这样的事情对你有用:

SELECT b.ID, a.NAME, b.Title, b.SID, b.Date
FROM TABLEA a
    INNER JOIN (SELECT SID, IFNULL(Title, "") AS Title,
                       MAX(IF(Title IS NULL, Date, NULL)) Date
                FROM TABLEB GROUP BY SID) b
        ON a.SID = b,SID;

答案 1 :(得分:0)

SELECT b.ID, a.NAME, b.Title, b.SID, b.Datea 
from tablea a left outer join 
  (( SELECT sid, MAX(datea) AS latest
         FROM tableb
          where title is not null 
          GROUP BY sid) AS dt
INNER JOIN tableb b  ON b.sid= dt.sid  and b.datea=dt.latest )
on a.sid=b.sid

答案 2 :(得分:0)

试试我的代码(可行):

SELECT b.id, b.title, b.sid, b.date 
    FROM table_b as b 
    JOIN table_a as a ON a.sid = b.sid
    WHERE b.id in (SELECT MAX(id) FROM table_b GROUP BY sid)