假设我有两张桌子,
表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
我知道如何使用子查询执行此操作但我想避免因某种原因使用子查询?
答案 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