微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从CASE语句分配给T-SQL变量

我想在查询中分配一些变量,这些变量对它的列使用CASE语句.不太确定如何做到这一点,无法找到正确的语法.

这是我到目前为止,但它有语法错误.

-- set @theID and @theName with their appropriate values
 select top (1) 
 @theID = (Case when B.ID IS NULL then A.ID else B.ID END),@theName = (Case when B.Name IS NULL then A.Name else B.Name END) 
 from B left join A on A.ID = B.ID where ...

将这些变量粘贴在那里的正确位置/方法是什么?

解决方法

你给出的例子应该有效.您可以从案例陈述中分配变量.只是假装整个CASE..WHEN..THEN..ELSE..END块是一个字段.这是一个通用的例子:
declare
  @string1 nvarchar(100) = null,@string2 nvarchar(100) = null
 ;

select top 1
  @string1 = case when 1=1 then 'yes' else 'no' end,@string2 = case when 1=0 then 'yes' else 'no' end

print 'string1 = ' + @string1
print 'string2 = ' + @string2

得到:

string1 = yes
string2 = no

你能告诉我们你得到的具体错误吗?

原文地址:https://www.jb51.cc/mssql/77826.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐