91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

泰和县| 咸宁市| 清流县| 来凤县| 永平县| 贵阳市| 江达县| 衡山县| 黄梅县| 宜春市| 崇仁县| 滦南县| 洛川县| 西平县| 辽源市| 晋宁县| 句容市| 巴中市| 九台市| 平塘县| 林周县| 朔州市| 金山区| 会同县| 清远市| 甘洛县| 榆林市| 彭阳县| 汉沽区| 临西县| 长丰县| 布拖县| 兴业县| 赤壁市| 图们市| 乐陵市| 土默特右旗| 太湖县| 迭部县| 水富县| 宜阳县|