|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
数据库技术
→
『 SQL Server论坛 』
→ 求助一条sql语句
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
627
人关注过本帖
标题:
求助一条sql语句
只看楼主
加入收藏
cqlhc1
等 级:
新手上路
帖 子:3
专家分:0
注 册:2013-12-23
结帖率:
0
楼主
收藏
已结贴
√
问题点数:20 回复次数:5
求助一条sql语句
表1
mo
st
1
a
2
b
3
c
表2
mo
st
1
aa
2
bb
3
cc
4
dd
注意"表2"要多一行
现在需要通过mo关系,把表1的st更新到表2的st里,但表2里多的行(也就是表1里没有的mo)更新为'0'
只用一条语句,能行吗,怎么写.
谢谢!
搜索更多相关主题的帖子:
sql语句
2013-12-23 14:55
举报帖子
使用道具
赠送鲜花
cqlhc1
等 级:
新手上路
帖 子:3
专家分:0
注 册:2013-12-23
第
2
楼
收藏
得分:0
update t2 set t2.st=case when not exists (select * from t1 where t2.mo=t1.mo) then '0'
else
(select st from t1 where t1.mo=t2.mo)
end
这样写好像可以
2013-12-24 11:23
举报帖子
使用道具
赠送鲜花
cqlhc1
等 级:
新手上路
帖 子:3
专家分:0
注 册:2013-12-23
第
3
楼
收藏
得分:0
update a set a.st= case
when b.mo=a.mo then b.st
else 0
end
from t1 b right join t2 a on b.mo=a.mo
这样写也行
2013-12-24 11:31
举报帖子
使用道具
赠送鲜花
qw1161748579
来 自:南充
等 级:
业余侠客
威 望:
1
帖 子:48
专家分:252
注 册:2013-9-23
第
4
楼
收藏
得分:20
update t2 set st = (case when t2.mo in (select mo from t1) then (select st from t1 where t1.mo = t2.mo) else '0' end)
2013-12-25 09:54
举报帖子
使用道具
赠送鲜花
清风幽闲
等 级:
新手上路
威 望:
3
帖 子:5
专家分:0
注 册:2014-3-3
第
5
楼
收藏
得分:0
UPDATE TB2 SET TB2.ST=CASE
WHEN TB2.MO=TB1.MO THEN TB1.ST
ELSE '0'
END
FROM TB1 JOIN TB2 ON TB1.MO=TB2.MO
2014-03-03 14:17
举报帖子
使用道具
赠送鲜花
西风独自凉
等 级:
贵宾
威 望:
43
帖 子:3380
专家分:28
注 册:2007-8-2
第
6
楼
收藏
得分:0
update t2 set t2.st=isnull(t1.st,'0') from t2 a left join t1 on t1.mo=a.mo
2014-03-04 11:29
举报帖子
使用道具
赠送鲜花
6
1/1页
1
快速回复:
求助一条sql语句
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.019626 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved