sqlserver 将一个表中的某些字段更新到另一个表中(转载)

来源:https://blog.csdn.net/qq_23888451/article/details/86615555 

https://blog.csdn.net/cyxinda/article/details/78254110

语法:

Oralce和DB2都支持的语法:
UPDATE A
SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)

MS SQL Server不支持这样的语法,相对应的写法为:
UPDATE A
    SET A1 = B1, A2 = B2, A3 = B3
    FROM A LEFT JOIN B ON A.ID = B.ID

 此处也可以 right join 、 inner join

UPDATE A
    SET A1 = B1, A2 = B2, A3 = B3
    FROM A, B WHERE A.ID = B.ID

Oracle和DB2中的写法就比较麻烦了,如下:
UPDATE A
    SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
    WHERE ID IN (SELECT B.ID FROM B WHERE A.ID = B.ID)

注:如果要更新的表A数据量过大,而且仅更新表A的部分数据,那么,需要在前面的语句中加入where筛选要操作的数据。

案例:

公司做的业务有个需求是将A表中的某些字段数据,更新到B表中的相应含义的字段中。
假设user、score表的字段如下:
user表

userId username password sex addr phone
1 张珊 123 男 北京市 1562356586
2 李思 456 女 北京市 1562354256
3 王武 789 男 北京市 1562345544
4 王柳 113 男 北京市 1562445778
score表

scoreId userId username score course phone
1 1 80 语文
2 1 85 数学
3 3 52 语文
4 2 67 数学
现在score表中的username和phone字段是空的,需要从user表中,查找出相应的值插入score表中,SQL语句如下:

update score
set score.username=user.username,score.phone=user.phone
from score,user
where score.userId=user.userId

扩展:

1将一张表中的数据插入到另一张表

 https://www.cnblogs.com/hao-1234-1234/p/8484353.html

2跨服务器增删改查

 https://www.cnblogs.com/hao-1234-1234/p/10277324.html

 

转载于:https://www.cnblogs.com/hao-1234-1234/p/10975489.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值