中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL Server中怎么使用Merge語句

發布時間:2021-08-05 15:05:17 來源:億速云 閱讀:117 作者:Leah 欄目:數據庫

本篇文章給大家分享的是有關SQL Server中怎么使用Merge語句,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

面舉一個例子來具體說明一下: 有兩個表SourceTable為登陸表,TargetTable為授權表,如果訪問用戶在登陸表中,更新授權表的授權級別,否則授權0表示游客。sql語句如下: --SourceTable為登陸表,TargetTable為授權表 --如果訪問用戶在登陸表中,更新授權表的授權級別,否則授權0表示游客。 create table SourceTable(UserName nvarchar(10),Pwd int,[Level] int) create table TargetTable(UserName nvarchar(10),[Level] int) go --下面是SQL Server2008新增的賦值功能,更多新功能請參見 insert into SourceTable values('user1','111',1),('user2','222',2),('user3','333',3) insert into TargetTable values('user1',1),('user2',2) 一般情況,我們會寫如下的語句:復制代碼 代碼如下: declare @UserName varchar(10) = 'user2'--表示某個登陸的用戶名 merge into TargetTable as tg using (select UserName,[Level] from SourceTable where UserName=@UserName) as sr(UserName,[Level]) on tg.UserName=sr.UserName when matched then update set [Level]=sr.[Level]--更新授權級別 when not matched by target then insert (UserName,[Level]) values(@UserName,0)--表示游客 output $action;

執行結果為UPDATE,表示執行了更新操作,也正是我們想要的。 但是如果我們把@UserName賦值為'user6',希望能在TargetTable中插入一條記錄,但是實際執行結果為空,顯示什么都沒執行。原因就是using (select UserName,[Level] from SourceTable where UserName=@UserName) as sr(UserName,[Level]) on tg.UserName=sr.UserName這個語句中,sr結果集為空,所以merge語句就不向后執行了,不知道這是不是SQL Server的bug。 下面的SQL可以解決上面的問題:復制代碼 代碼如下: declare @UserName varchar(10) = 'user7'--表示某個登陸的用戶名 merge into TargetTable as tg using (select @UserName) as sr(UserName) on tg.UserName=sr.UserName when matched then update set [Level]= (select top 1 [Level] from SourceTable where UserName=@UserName) --更新授權級別 when not matched by target then insert (UserName,[Level]) values(@UserName,0)--表示游客 output $action;

以上就是SQL Server中怎么使用Merge語句,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

加查县| 定日县| 辽源市| 浦县| 英吉沙县| 濮阳市| 丁青县| 边坝县| 海晏县| 盱眙县| 阿克陶县| 读书| 民勤县| 蓬溪县| 淄博市| 佳木斯市| 定襄县| 邮箱| 灵武市| 临潭县| 合江县| 奉贤区| 元谋县| 慈溪市| 遂川县| 尚义县| 平乐县| 齐齐哈尔市| 高州市| 泰兴市| 潞西市| 息烽县| 独山县| 阳原县| 昭平县| 体育| 涞源县| 夹江县| 永福县| 格尔木市| 元朗区|