sql中,如果有两条一样的数据,根据某个字段的最大值取另一个字段的值怎么写?

需要将表t1的B1字段的值付给t2表的B2,而且t1.D1=t2.A2,并且t1.C1=2000,但是第一条数据和第三条这两点都一样,我需要取的是第三条,也就是最新产生的... 需要将表t1的B1字段的值付给t2表的B2,而且t1.D1=t2.A2 ,并且t1.C1=2000,但是第一条数据和第三条这两点都一样,我需要取的是第三条,也就是最新产生的数据,这个应该怎么写?谢谢各位
例如:
t1
A1 B1 C1 D1
1 一 2000 100
2 二 2001 101
3 三 2000 100
t2
A2 B2
100

101
展开
 我来答
unique_lele
2013-07-12 · TA获得超过112个赞
知道小有建树答主
回答量:210
采纳率:100%
帮助的人:155万
展开全部
update T2 set T2.B2=T1.B1 from (Select max(A1) as A1,C1,D1 from T1 group by C1,D1) T3 left join T1 On T3.A1=T1.A1 left join T2 on t1.D1=t2.A2 where t1.C1=2000

我的想法就是 把T1一样的合成一条 找到最大的A1 。然后用找到的A1去从新查一下T1表 。这样就不会有两条一样的数据。
微风8009
2013-07-12 · TA获得超过304个赞
知道小有建树答主
回答量:251
采纳率:0%
帮助的人:164万
展开全部
update c
set B2=b.B1
from
(
select A1=max(A1),D1 from t1 group by D1
) a
inner join t1 b on a.A1=b.A1 and a.D1=b.D1
left join t2 c on a.D1=c.A2
where b.C1=2000

应该行的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
清水栞
2013-07-12 · TA获得超过1547个赞
知道小有建树答主
回答量:1538
采纳率:50%
帮助的人:973万
展开全部
写是可以写了,但是性能很低下的。。。你是以哪个字段判断“最新”?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式