免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3153 | 回复: 2
打印 上一主题 下一主题

问个根据一表中的条件更新另一表的值的Sql语句 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-02-11 21:22 |只看该作者 |倒序浏览
假设有表a,b

a中有x,y,z列
b中有x,y,v列

现要更新b表中的v列的值,并要求b表中的x,y列的内容要和a表中的x,y列的内容相同

Sql语句该怎么写?

论坛徽章:
0
2 [报告]
发表于 2009-02-11 21:47 |只看该作者
a,b表先关联为一个中间表c,然后更新即可

论坛徽章:
0
3 [报告]
发表于 2009-02-11 23:01 |只看该作者
如果a表中(x,y)为primary key的话,可以这样
update
(select b.v, a.z from a, b
where a.x = b.x and a.y = b.y)
set v = z;
如果a表中(x,y)不是primary key的话,但(x,y)的数据的确是唯一的(如果不唯一的话,这样的update的结果就有不确定性,而且下面的SQL也会出错)
可以这样做:
update a
set v = (select z from b where a.x = b.x and a.y = b.y)
where exists (select 'x' from b where a.x = b.x and a.y = b.y);

[ 本帖最后由 doni 于 2009-2-11 23:03 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP