使用其中一个表的最大值来连接表

时间:2015-12-09 17:29:50

标签: sql db2

我在ID列上连接两个表以及EVNT_SEQ的最大值时遇到困难。例如,我有一个充满用户的表,我想看看他们最近的行动。 evnt_tbl为每个用户事件添加一行。我想编写一个返回所有用户及其最新事件(EVNT_SEQ的MAX)的查询。

数据库版本:IBM DB2 9.7.8

person_tbl

ID    NAME
1     Ben
2     Joe
3     Jane
4     Albert
5     Paul

evnt_tbl

ID    EVNT_SEQ    EVNT_NM
1     1           NULL
1     2           max
2     1           NULL
2     2           NULL
2     3           max
3     1           max
4     1           NULL
4     2           max
5     1           NULL
5     2           max

所需的查询结果

ID    NAME     EVNT_SEQ    EVNT_NM
1     Ben      2           max
2     Joe      3           max
3     Jane     1           max
4     Albert   2           max
5     Paul     2           max

我以为我可以写下面的内容,但是我收到了一个错误:

SELECT person.ID, person.NAME, evnt.EVNT_SEQ, evnt.EVNT_NM
FROM person_tbl person
LEFT JOIN evnt_tbl evnt ON person_tbl.ID = evnt.ID
    AND evnt.EVNT_SEQ = (SELECT MAX(EVNT_SEQ) 
                             FROM event_tbl evnt2 
                             WHERE evnt.ID = evnt2.ID)

2 个答案:

答案 0 :(得分:0)

使用派生表获取事件表中每个id的最大值。然后将结果加入人员表。

select t.id, p.name, t.maxevseqm, t.maxevnum
from (SELECT ID, max(EVNT_SEQ) as maxevseq, max(EVNT_NM) as maxevnum
      FROM event_tbl
      group by id) t
join person_tbl on p.id = t.id

答案 1 :(得分:0)

select
  p.id, p.name, e.EVNT_SEQ, e.EVNT_NM
from 
  person_tbl p
inner join
  evnt_tbl e
on 
  p.id = e.id and e.EVNT_SEQ =
  (
  select MAX(EVNT_SEQ)
  from evnt_tbl xe
  where xe.id = p.id
  ) 

使用SQLFIDDLE

进行测试