同一个表,用一条数据更新另一条数据

同一张表,用一条数据更新另一条数据。

sql 数据自更新sql。

sql  表自连接更新。

 

ms sqlserver支持

UPDATE Table1
SET Col2 = t2.Col2,Col3 = t2.Col3
FROM Table1 t1
INNER JOIN Table2 t2 ON t1.Col1 = t2.Col1
WHERE t1.Col1 IN (21, 31)
GO

 

ms sqlserver支持

update  u  set u.CityId=u2.CityId  
from sys_User u 
inner join  sys_User u2  on u.U_LoginName='newUser' and u2.U_LoginName='oldUser'

 

ms sqlserver支持

update  u  set u.CityId=u2.CityId  
from sysUser u ,sysUser u2  where u.LoginName='newUser' and u2.LoginName='oldUser'

 

ms sqlserver支持(常规方式)

update sysUser set CityId=(select CityId from sysUser where LoginName='oldUser') where LoginName='newUser'

 

仅orecle数据库支持

update (
select u.CityId c1,u2.CityId c2 from sysUser u 
inner join  sysUser u2  on u.LoginName='newUser' and u2.LoginName='odlUser')
set c1=c2;

 

以上内容为与群友讨论得到。

 

转载于:https://www.cnblogs.com/Tpf386/p/8708857.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值