Oralce和DB2都支持的语法:
关于Update语句在不同数据库中的差别(zz)UPDATE A 
关于Update语句在不同数据库中的差别(zz) 
SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)

MS SQL Server不支持这样的语法,相对应的写法为:
关于Update语句在不同数据库中的差别(zz)UPDATE A 
关于Update语句在不同数据库中的差别(zz)    
SET A1 = B1, A2 = B2, A3 = B3 
关于Update语句在不同数据库中的差别(zz)    
FROM A LEFT JOIN B ON A.ID = B.ID

个人感觉MS SQL Server的Update语法功能更为强大。MS SQL SERVER的写法:
关于Update语句在不同数据库中的差别(zz)UPDATE A 
关于Update语句在不同数据库中的差别(zz)    
SET A1 = B1, A2 = B2, A3 = B3
关于Update语句在不同数据库中的差别(zz)    
FROM A, B WHERE A.ID = B.ID

在Oracle和DB2中的写法就比较麻烦了,如下:
关于Update语句在不同数据库中的差别(zz)UPDATE A 
关于Update语句在不同数据库中的差别(zz)    
SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
关于Update语句在不同数据库中的差别(zz)    
WHERE ID IN (SELECT B.ID FROM B WHERE A.ID = B.ID)

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-23
  • 2021-09-30
猜你喜欢
  • 2021-10-09
  • 2022-12-23
  • 2021-11-14
  • 2022-12-23
  • 2021-10-20
  • 2022-01-12
相关资源
相似解决方案