SQL UPDATE語(yǔ)句在DB2、Oralce、SQL Server中的不同
SQL UPDATE語(yǔ)句用于更新數(shù)據(jù)庫(kù)中的數(shù)據(jù),SQL UPDATE語(yǔ)句在不同的數(shù)據(jù)庫(kù)寫法都不太一樣,本文將為您分別舉例說(shuō)明DB2、Oralce、SQL Server三種數(shù)據(jù)庫(kù)中SQL UPDATE語(yǔ)句的使用異同,供您參考,希望對(duì)您有所幫助。
Oralce和DB2都支持的語(yǔ)法:
UPDATE A 
 SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
MS SQL Server不支持這樣的語(yǔ)法,相對(duì)應(yīng)的寫法為:
UPDATE A 
    SET A1 = B1, A2 = B2, A3 = B3 
    FROM A LEFT JOIN B ON A.ID = B.ID
個(gè)人感覺(jué)MS SQL Server的Update語(yǔ)法功能更為強(qiáng)大。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)
 
【編輯推薦】















 
 
 
 
 
 
 