Update語句在不同數據庫中的差別

Oralce和DB2都支持的語法:
None.gifUPDATE A 
None.gif 
SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)

MS SQL Server不支持這樣的語法,相對應的寫法爲:
None.gifUPDATE A 
None.gif    
SET A1 = B1, A2 = B2, A3 = B3 
None.gif    
FROM A LEFT JOIN B ON A.ID = B.ID

個人感覺MS SQL Server的Update語法功能更爲強大。MS SQL SERVER的寫法:
None.gifUPDATE A 
None.gif    
SET A1 = B1, A2 = B2, A3 = B3
None.gif    
FROM A, B WHERE A.ID = B.ID

在Oracle和DB2中的寫法就比較麻煩了,如下:
None.gifUPDATE A 
None.gif    
SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
None.gif    
WHERE ID IN (SELECT B.ID FROM B WHERE A.ID = B.ID)
發佈了55 篇原創文章 · 獲贊 3 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章