0

如何在 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 不同)的一条记录,其中标题不为空,然后显示

标题的最大日期为空字段。

结果想要空标题的最大日期:

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**

怎么做 ?

4

3 回答 3

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;
于 2012-07-31T04:09:05.207 回答
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
于 2012-07-31T04:12:38.987 回答
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)
于 2012-07-31T04:43:59.403 回答