SQLServer中merge函數(shù)用法詳解
Merge關(guān)鍵字是一個神奇的DML關(guān)鍵字。它在SQL Server 2008被引入,它能將Insert,Update,Delete簡單的并為一句。MSDN對于Merge的解釋非常的短小精悍:”根據(jù)與源表聯(lián)接的結(jié)果,對目標(biāo)表執(zhí)行插入、更新或刪除操作。
MERGE 目標(biāo)表
USING 源表
ON 匹配條件
WHEN MATCHED THEN
語句
WHEN NOT MATCHED THEN
語句;
其中最后語句分號不可以省略,且源表既可以是一個表也可以是一個子查詢語句
WHEN NOT MATCHED BY TARGET
表示目標(biāo)表不匹配,BY TARGET是默認的,所以上面我們直接使用WHEN NOT MATCHED THEN
WHEN NOT MATCHED BY SOURCE
表示源表不匹配,即目標(biāo)表中存在,源表中不存在的情況。
主要用法:
merge無法多次更新同一行,也無法更新和刪除同一行
當(dāng)源表和目標(biāo)表不匹配時:若數(shù)據(jù)是源表有目標(biāo)表沒有,則進行插入操作若數(shù)據(jù)是源表沒有而目標(biāo)表有,則進行更新或者刪除數(shù)據(jù)操作當(dāng)源表和目標(biāo)表匹配時:進行更新操作或者刪除操作when matched 這個子句可以有兩個,當(dāng)有兩個時,第一個子句必須是when matched and condition且兩個matched子句只會執(zhí)行一個,且兩個子句必須是一個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的網(wǎng)址
在 Merge Matched 操作中,只能允許執(zhí)行 UPDATE 或者 DELETE 語句。
在 Merge Not Matched 操作中,只允許執(zhí)行 INSERT 語句。
一個 Merge 語句中出現(xiàn)的 Matched 操作,只能出現(xiàn)一次 UPDATE 或者 DELETE 語句,否則就會出現(xiàn)下面的錯誤 - An action of type 'WHEN MATCHED' cannot appear more than once in a 'UPDATE' clause of a MERGE statement.
Merge 語句最后必須包含分號,以 ; 結(jié)束。
ps:SQL Server中Merge-using的用法
在執(zhí)行之前:
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(沒有匹配成功 當(dāng)然不能update了) then insert (UserName,Sex)values('ZhangZhao','b');
執(zhí)行之后
Merge和using搭配用于特別是BI上數(shù)據(jù)統(tǒng)計和分析上 比如 要求子表中沒有的數(shù)據(jù)那么父表中就要刪除對應(yīng)的數(shù)據(jù) 保證子表和父表的數(shù)據(jù)對應(yīng) 如果按照常規(guī)的做法是 跑個作業(yè) 然后通過游標(biāo)/表值函數(shù)/臨時表等等循環(huán)的獲取數(shù)據(jù)然后更新父表 這樣是很浪費效率的 這時Merge派上用場了。
相關(guān)文章
T-sql語句修改SQL Server數(shù)據(jù)庫邏輯名、數(shù)據(jù)庫名、物理名的方法
這篇文章主要介紹了T-sql語句修改SQL Server數(shù)據(jù)庫邏輯名、數(shù)據(jù)庫名、物理名的方法,結(jié)合實例形式分析了T-SQL語句操作數(shù)據(jù)庫的基本技巧,非常簡單易懂,需要的朋友可以參考下2016-06-06此數(shù)據(jù)庫沒有有效所有者,因此無法安裝數(shù)據(jù)庫關(guān)系圖支持對象
此數(shù)據(jù)庫沒有有效所有者,因此無法安裝數(shù)據(jù)庫關(guān)系圖支持對象。若要繼續(xù),請首先使用“數(shù)據(jù)庫屬性”對話框的“文件”頁或ALTER AUTHORIZATION語句將數(shù)據(jù)庫所有者設(shè)置為有效登錄名,然后再添加數(shù)據(jù)庫關(guān)系圖支持對象2012-01-01深入SQL SERVER合并相關(guān)操作Union,Except,Intersect的詳解
本篇文章是對SQL SERVER合并相關(guān)操作Union,Except,Intersect進行了詳細的分析介紹,需要的朋友參考下2013-06-06如何創(chuàng)建支持FILESTREAM的數(shù)據(jù)庫示例探討
FILESTREAM使用一種特殊類型的文件組,因此在創(chuàng)建數(shù)據(jù)庫時,必須至少為一個文件組指定 CONTAINS FILESTREAM 子句接下來為你詳細介紹下如何創(chuàng)建支持 FILESTREAM 的數(shù)據(jù)庫2013-03-03