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

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

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