zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

SQL UPDATE语句在DB2、Oralce、SQL Server中的不同

2023-04-18 15:55:28 时间

SQL UPDATE语句用于更新数据库中的数据,SQL UPDATE语句在不同的数据库写法都不太一样,本文将为您分别举例说明DB2、Oralce、SQL Server三种数据库中SQL UPDATE语句的使用异同,供您参考,希望对您有所帮助。

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

个人感觉MS SQL Server的Update语法功能更为强大。MS SQL SERVER的写法:

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)
 

 

 

【编辑推荐】

使用SQL Delete命令删除记录

SQL Server创建表和删除表

SQL SERVER TOC分页的实现方法

sql server系统表说明

SQL Server创建分区函数的方法