SQLServer中merge函數(shù)如何使用

本篇文章給大家分享的是有關(guān)SQLServer中merge函數(shù)如何使用,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

成都創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),壽陽(yáng)網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:壽陽(yáng)等地區(qū)。壽陽(yáng)做網(wǎng)站價(jià)格咨詢:13518219792

Merge關(guān)鍵字是一個(gè)神奇的DML關(guān)鍵字。它在SQL Server 2008被引入,它能將Insert,Update,Delete簡(jiǎn)單的并為一句。MSDN對(duì)于Merge的解釋非常的短小精悍:”根據(jù)與源表聯(lián)接的結(jié)果,對(duì)目標(biāo)表執(zhí)行插入、更新或刪除操作。

MERGE 目標(biāo)表

USING 源表

ON 匹配條件

WHEN MATCHED THEN

語(yǔ)句

WHEN NOT MATCHED THEN

語(yǔ)句;

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

WHEN NOT MATCHED BY TARGET

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

WHEN NOT MATCHED BY SOURCE

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

主要用法:

merge無(wú)法多次更新同一行,也無(wú)法更新和刪除同一行

當(dāng)源表和目標(biāo)表不匹配時(shí):若數(shù)據(jù)是源表有目標(biāo)表沒(méi)有,則進(jìn)行插入操作若數(shù)據(jù)是源表沒(méi)有而目標(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 ausing icr_codemap as bon a.COLNAME = b.COLNAME and a.ctcode = b.ctcodewhen matched and b.pbcode <> a.pbcodethen update set a.pbcode = b.pbcodewhen not matchedthen insert values(b.colname,b.ctcode,b.pbcode,b.note);

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

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

在 Merge Matched 操作中,只能允許執(zhí)行 UPDATE 或者 DELETE 語(yǔ)句。在 Merge Not Matched 操作中,只允許執(zhí)行 INSERT 語(yǔ)句。一個(gè) Merge 語(yǔ)句中出現(xiàn)的 Matched 操作,只能出現(xiàn)一次 UPDATE 或者 DELETE 語(yǔ)句,否則就會(huì)出現(xiàn)下面的錯(cuò)誤 - An action of type 'WHEN MATCHED' cannot appear more than once in a 'UPDATE' clause of a MERGE statement.Merge 語(yǔ)句最后必須包含分號(hào),以 ; 結(jié)束。

ps:SQL Server中Merge-using的用法

在執(zhí)行之前:

merge into UserInfo uusing chartinfo c on u.UserId=c.UserIdwhen matched and u.UserName=c.UserName then update set u.lastUpdate=c.LastUpdatewhen not matched --為not matched時(shí) 不能為update(沒(méi)有匹配成功 當(dāng)然不能update了) then insert (UserName,Sex)values('ZhangZhao','b');

執(zhí)行之后

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

以上就是SQLServer中merge函數(shù)如何使用,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文標(biāo)題:SQLServer中merge函數(shù)如何使用
標(biāo)題網(wǎng)址:http://bm7419.com/article16/psogdg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開(kāi)發(fā)、外貿(mào)網(wǎng)站建設(shè)App設(shè)計(jì)、動(dòng)態(tài)網(wǎng)站、關(guān)鍵詞優(yōu)化、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管