主頁 > 知識(shí)庫 > SQLServer中merge函數(shù)用法詳解

SQLServer中merge函數(shù)用法詳解

熱門標(biāo)簽:AI電銷 呼叫中心市場需求 百度競價(jià)排名 鐵路電話系統(tǒng) Linux服務(wù)器 地方門戶網(wǎng)站 網(wǎng)站排名優(yōu)化 服務(wù)外包

Merge關(guān)鍵字是一個(gè)神奇的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

語句;

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

WHEN NOT MATCHED BY TARGET

表示目標(biāo)表不匹配,BY TARGET是默認(rèn)的,所以上面我們直接使用WHEN NOT MATCHED THEN

WHEN NOT MATCHED BY SOURCE

表示源表不匹配,即目標(biāo)表中存在,源表中不存在的情況。

主要用法:

merge無法多次更新同一行,也無法更新和刪除同一行

當(dāng)源表和目標(biāo)表不匹配時(shí):若數(shù)據(jù)是源表有目標(biāo)表沒有,則進(jìn)行插入操作若數(shù)據(jù)是源表沒有而目標(biāo)表有,則進(jìn)行更新或者刪除數(shù)據(jù)操作當(dāng)源表和目標(biāo)表匹配時(shí):進(jìn)行更新操作或者刪除操作when matched 這個(gè)子句可以有兩個(gè),當(dāng)有兩個(gè)時(shí),第一個(gè)子句必須是when matched and condition且兩個(gè)matched子句只會(huì)執(zhí)行一個(gè),且兩個(gè)子句必須是一個(gè)update和一個(gè)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)
;

可以比對字段不一致進(jìn)行更新

https://technet.microsoft.com/zh-cn/library/bb510625.aspx  這個(gè)是MSDN的網(wǎng)址

在 Merge Matched 操作中,只能允許執(zhí)行 UPDATE 或者 DELETE 語句。
在 Merge Not Matched 操作中,只允許執(zhí)行 INSERT 語句。
一個(gè) Merge 語句中出現(xiàn)的 Matched 操作,只能出現(xiàn)一次 UPDATE 或者 DELETE 語句,否則就會(huì)出現(xiàn)下面的錯(cuò)誤 - 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時(shí) 不能為update(沒有匹配成功 當(dāng)然不能update了)
 then insert (UserName,Sex)values('ZhangZhao','b');

執(zhí)行之后

Merge和using搭配用于特別是BI上數(shù)據(jù)統(tǒng)計(jì)和分析上 比如 要求子表中沒有的數(shù)據(jù)那么父表中就要?jiǎng)h除對應(yīng)的數(shù)據(jù) 保證子表和父表的數(shù)據(jù)對應(yīng) 如果按照常規(guī)的做法是 跑個(gè)作業(yè) 然后通過游標(biāo)/表值函數(shù)/臨時(shí)表等等循環(huán)的獲取數(shù)據(jù)然后更新父表  這樣是很浪費(fèi)效率的  這時(shí)Merge派上用場了。

您可能感興趣的文章:
  • SqlServer2000+ 身份證合法校驗(yàn)函數(shù)的示例代碼
  • Sqlserver 自定義函數(shù) Function使用介紹
  • SQLServer行列互轉(zhuǎn)實(shí)現(xiàn)思路(聚合函數(shù))
  • SQLSERVER分頁查詢關(guān)于使用Top方式和row_number()解析函數(shù)的不同
  • SQLServer中Partition By及row_number 函數(shù)使用詳解
  • sqlserver四舍五入使用round函數(shù)及cast和convert函數(shù)
  • 談?wù)剆qlserver自定義函數(shù)與存儲(chǔ)過程的區(qū)別
  • SQLServer之常用函數(shù)總結(jié)詳解

標(biāo)簽:銅川 黃山 崇左 湘潭 衡水 蘭州 湖南 仙桃

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQLServer中merge函數(shù)用法詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266