不使用SubQuery的父子查询

时间:2011-12-12 16:24:59

标签: sql sql-server oracle

假设我有两张桌子,

表A

ID  Name
--  ----
 1   A
 2   B

表B

AID  Date
--  ----
 1   1/1/2000
 1   1/2/2000
 2   1/1/2005
 2   1/2/2005

现在我需要这个结果而不使用子查询,

ID  Name  Date
--  ----  ----
 1   A    1/2/2000
 2   B    1/2/2005

我知道如何使用子查询执行此操作但我想避免因某种原因使用子查询?

3 个答案:

答案 0 :(得分:6)

如果我的意思正确并且您需要表中的最新日期,那么下面的查询应该这样做:

select a.id,a.name,max(b.date)
from TableA a
join TableB b on b.aid = a.id
group by a.id,a.name

答案 1 :(得分:5)

SELECT a.ID, a.Name, MAX(B.Date)
FROM TableA A
INNER JOIN TableB B
    ON B.ID = A.ID
GROUP BY A.id, A.name

这是一个简单的聚合。看起来你想要每个id / name组合的最高日期。

答案 2 :(得分:1)

create table #t1 (id int, Name varchar(10))
create table #t2 (Aid int, Dt date)

insert #t1 values (1, 'A'), (2, 'B')
insert #t2 values (1, '1/1/2000'), (1, '1/2/2000'), (2, '1/1/2005'), (2, '1/2/2005')


;WITH cte (AId, MDt)
as
(
select Aid, MAX(Dt) from #t2 group by AiD
)
select #t1.Id, #t1.Name, cte.MDt
from #t1
join cte
    on cte.AId = #t1.Id