SQLServer中merge函數用法詳解。本站提示廣大學習愛好者:(SQLServer中merge函數用法詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是SQLServer中merge函數用法詳解正文
Merge症結字是一個奇異的DML症結字。它在SQL Server 2008被引入,它能將Insert,Update,Delete簡略的並為一句。MSDN關於Merge的說明異常的短小精干:”依據與源表聯接的成果,對目的表履行拔出、更新或刪除操作。
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 語句最初必需包括分號,以 ; 停止。
ps:SQL Server中Merge-using的用法
在履行之前:
merge into UserInfo u using chartinfo c on u.UserId=c.UserId when matched and u.UserName=c.UserName then update set u.lastUpdate=c.LastUpdate when not matched --為not matched時 不克不及為update(沒有婚配勝利 固然不克不及update了) then insert (UserName,Sex)values('ZhangZhao','b');
履行以後
Merge和using搭配用於特殊是BI上數據統計和剖析上 好比 請求子表中沒有的數據那末父表中就要刪除對應的數據 包管子表和父表的數據對應 假如依照慣例的做法是 跑個功課 然後經由過程游標/表值函數/暫時表等等輪回的獲得數據然後更新父表 如許是很糟蹋效力的 這時候Merge派上用處了。