亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2015年11月23日 15:23:54   作者:子非魚220  
Merge關(guān)鍵字是一個(gè)神奇的DML關(guān)鍵字。它在SQL Server 2008被引入,它能將Insert,Update,Delete簡(jiǎn)單的并為一句。通過本篇文章給大家介紹sqlserver中merge函數(shù)用法詳解,感興趣的朋友一起學(xué)習(xí)吧

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

語句

WHEN NOT MATCHED THEN

語句;

其中最后語句分號(hào)不可以省略,且源表既可以是一個(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)
;

可以比對(duì)字段不一致進(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 語句最后必須包含分號(hào),以 ; 結(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除對(duì)應(yīng)的數(shù)據(jù) 保證子表和父表的數(shù)據(jù)對(duì)應(yīng) 如果按照常規(guī)的做法是 跑個(gè)作業(yè) 然后通過游標(biāo)/表值函數(shù)/臨時(shí)表等等循環(huán)的獲取數(shù)據(jù)然后更新父表  這樣是很浪費(fèi)效率的  這時(shí)Merge派上用場(chǎng)了。

相關(guān)文章

  • 自增長(zhǎng)鍵列統(tǒng)計(jì)信息的處理方法

    自增長(zhǎng)鍵列統(tǒng)計(jì)信息的處理方法

    在這篇文章展示了SQL Server的查詢優(yōu)化器如何使用自增長(zhǎng)鍵列統(tǒng)計(jì)信息,大家都知道SQLServer里每個(gè)統(tǒng)計(jì)信息對(duì)象都有關(guān)聯(lián)的直方圖直方圖用多個(gè)步長(zhǎng)描述指定列數(shù)據(jù)分布情況,需要的朋友可以參考下
    2015-07-07
  • T-sql語句修改SQL Server數(shù)據(jù)庫邏輯名、數(shù)據(jù)庫名、物理名的方法

    T-sql語句修改SQL Server數(shù)據(jù)庫邏輯名、數(shù)據(jù)庫名、物理名的方法

    這篇文章主要介紹了T-sql語句修改SQL Server數(shù)據(jù)庫邏輯名、數(shù)據(jù)庫名、物理名的方法,結(jié)合實(shí)例形式分析了T-SQL語句操作數(shù)據(jù)庫的基本技巧,非常簡(jiǎn)單易懂,需要的朋友可以參考下
    2016-06-06
  • 此數(shù)據(jù)庫沒有有效所有者,因此無法安裝數(shù)據(jù)庫關(guān)系圖支持對(duì)象

    此數(shù)據(jù)庫沒有有效所有者,因此無法安裝數(shù)據(jù)庫關(guān)系圖支持對(duì)象

    此數(shù)據(jù)庫沒有有效所有者,因此無法安裝數(shù)據(jù)庫關(guān)系圖支持對(duì)象。若要繼續(xù),請(qǐng)首先使用“數(shù)據(jù)庫屬性”對(duì)話框的“文件”頁或ALTER AUTHORIZATION語句將數(shù)據(jù)庫所有者設(shè)置為有效登錄名,然后再添加數(shù)據(jù)庫關(guān)系圖支持對(duì)象
    2012-01-01
  • sql語句中臨時(shí)表使用實(shí)例詳解

    sql語句中臨時(shí)表使用實(shí)例詳解

    當(dāng)需要的結(jié)果需要經(jīng)過多次處理后才能最終得到我們需要的結(jié)果時(shí),就可以使用臨時(shí)表,這里臨時(shí)表就起到了一個(gè)中間處理的作用,實(shí)現(xiàn)了分步處理,簡(jiǎn)化了問題,這篇文章主要介紹了sql語句中臨時(shí)表使用方法,需要的朋友可以參考下
    2023-02-02
  • 深入SQL SERVER合并相關(guān)操作Union,Except,Intersect的詳解

    深入SQL SERVER合并相關(guān)操作Union,Except,Intersect的詳解

    本篇文章是對(duì)SQL SERVER合并相關(guān)操作Union,Except,Intersect進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • SQL Server全文檢索查詢淺析

    SQL Server全文檢索查詢淺析

    因?yàn)轫?xiàng)目需要,需要對(duì)上傳的文件內(nèi)容進(jìn)行查詢。通過MSDN了解到Windows索引服務(wù)可以實(shí)現(xiàn)對(duì)文件的全文檢索,并可以通過SQL Server進(jìn)行查詢。項(xiàng)目將這兩者結(jié)合,實(shí)現(xiàn)對(duì)上傳文件的全文檢索的解決方案。
    2009-11-11
  • SQL Server 2000的安全配置

    SQL Server 2000的安全配置

    SQL Server 2000的安全配置...
    2006-10-10
  • 如何創(chuàng)建支持FILESTREAM的數(shù)據(jù)庫示例探討

    如何創(chuàng)建支持FILESTREAM的數(shù)據(jù)庫示例探討

    FILESTREAM使用一種特殊類型的文件組,因此在創(chuàng)建數(shù)據(jù)庫時(shí),必須至少為一個(gè)文件組指定 CONTAINS FILESTREAM 子句接下來為你詳細(xì)介紹下如何創(chuàng)建支持 FILESTREAM 的數(shù)據(jù)庫
    2013-03-03
  • sql查詢點(diǎn)滴記錄

    sql查詢點(diǎn)滴記錄

    做.NET有一段時(shí)間了,如果說不會(huì)sql,那肯定是假的,但是真的掌握嗎
    2011-12-12
  • Hive-SQL查詢連續(xù)活躍登錄用戶思路詳解

    Hive-SQL查詢連續(xù)活躍登錄用戶思路詳解

    這篇文章主要介紹了Hive-SQL查詢連續(xù)活躍登陸的用戶,活躍用戶這里是指連續(xù)2天都活躍登錄的用戶,本文給大家分享解決思路及sql語句,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12

最新評(píng)論