SQL Server使用Merge语句当源表数据集为空时,无法进行查询的问题
来源:互联网 发布:第七感时时彩软件 编辑:程序博客网 时间:2024/04/29 09:16
今天使用Merge语句时遇到了一个问题,当源表数据集为空时,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新增的赋值功能,更多新功能请参见--http://blog.csdn.net/tjvictor/archive/2009/07/14/4346916.aspxinsert 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 tgusing (select UserName,[Level] from SourceTable where UserName=@UserName) as sr(UserName,[Level]) on tg.UserName=sr.UserNamewhen 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 tgusing (select @UserName) as sr(UserName) on tg.UserName=sr.UserNamewhen 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语句当源表数据集为空时,无法进行查询的问题
- SQL Server使用Merge语句当源表数据集为空时,无法进行查询的问题
- SQL Server使用Merge语句当源表数据集为空时,无法进行查询的问题
- 当使用hql进行投影查询时对于外键为空的记录查询不出来的问题
- 使用sql 语句查询当月/当天/当周的数据
- SQL 查询的语句不能为空
- SQL Server-使用Merge语句实现表数据之间的对比同步
- SQL Server Merge语句的使用
- Gridview分页查询数据,当数据为空时候在查询语句中的判断
- 查询EXCEL数据时,列数据为空的问题
- SQL执行查询时出现返回数据为空的问题
- sql server 2012 merge的使用,同构表merger,异构表merge, 当merge 与trigger 同时使用时较容易出错
- 解决hql语句查询条件为中文时结果集为空,为英文查询条件时不为空的问题
- “空”的艺术-当数据为空时显示什么
- “空”的艺术-当数据为空时显示什么
- “空”的艺术-当数据为空时显示什么
- “空”的艺术-当数据为空时显示什么
- SQL Server自定义函数进行模糊查询返回表类型没有数据的问题
- e.printStackTrace()
- 开心网模式的个人见解(转javaeye,原作者sharong)
- To Install SAP JCo on Windows 32
- linux下解压命令大全
- 读书使人优美
- SQL Server使用Merge语句当源表数据集为空时,无法进行查询的问题
- SQL Server 2008 新类型介绍之Date和Time
- 守护进程
- Enterprise Architect 7 入门教程
- SQL Server 排序函数 ROW_NUMBER和RANK 用法总结
- 百度空间的密码丢了
- SQL Server 中使用参数化Top语句
- 20 Linux System Monitoring Tools Every SysAdmin Should Know
- 明天是小年。