SQLServer之merge函數用法

來源:互聯網
上載者:User

標籤:

MERGE 目標表
USING 源表
ON 匹配條件
WHEN MATCHED THEN
語句
WHEN NOT MATCHED THEN
語句;

其中最後語句分號不可以省略,且源表既可以是一個表也可以是一個子查詢語句

WHEN NOT MATCHED BY TARGET
表示目標表不匹配,BY TARGET是預設的,所以上面我們直接使用WHEN NOT MATCHED THEN
WHEN NOT MATCHED BY SOURCE
表示源表不匹配,即目標表中存在,源表中不存在的情況。

主要用法:
merge無法多次更新同一行,也無法更新和刪除同一行
當源表和目標表不匹配時:
若資料是源表有目標表沒有,則進行插入操作
若資料是源表沒有而目標表有,則進行更新或者刪除資料操作
當源表和目標表匹配時:
進行更新操作或者刪除操作

when matched 這個子句可以有兩個,當有兩個時,第一個子句必須是when matched and condition且兩個matched子句只會執行一個,且兩個子句必須
是一個update和一個delete操作
when not matched by source和上面類似

merge icr_codemap_bak as a
using icr_codemap as b
on a.COLNAME = b.COLNAME and a.ctcode = b.ctcode
when matched and b.pbcode <> a.pbcode
then update set a.pbcode = b.pbcode
when not matched
then insert values(b.colname,b.ctcode,b.pbcode,b.note)
;
可以比對欄位不一致進行更新
https://technet.microsoft.com/zh-cn/library/bb510625.aspx這個是MSDN的網址


在 Merge Matched 操作中,只能允許執行 UPDATE 或者 DELETE 語句。
在 Merge Not Matched 操作中,只允許執行 INSERT 語句。
一個 Merge 語句中出現的 Matched 操作,只能出現一次 UPDATE 或者 DELETE 語句,否則就會出現下面的錯誤 - An action of type ‘WHEN MATCHED‘ cannot appear more than once in a ‘UPDATE‘ clause of a MERGE statement.
Merge 語句最後必須包含分號,以 ; 結束。

 

SQLServer之merge函數用法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.