首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从CASE语句中赋值给T-SQL变量

从CASE语句中赋值给T-SQL变量
EN

Stack Overflow用户
提问于 2011-08-05 01:35:57
回答 3查看 38.7K关注 0票数 7

我想在使用CASE语句作为其列的查询中赋值一些变量。不太确定如何做到这一点,有困难找到正确的语法。

到目前为止,这就是我所知道的,但是它有语法错误。

代码语言:javascript
运行
复制
 -- 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 ...

将这些变量放入其中的正确位置/方法是什么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-08-05 02:05:00

你所举的例子应该是有效的。您可以从case语句中为变量赋值。只要假设整个CASE..WHEN..THEN..ELSE..END块是一个字段即可。下面是一个通用的示例:

代码语言:javascript
运行
复制
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

提供:

代码语言:javascript
运行
复制
string1 = yes
string2 = no

您能告诉我们您得到的具体错误是什么吗?

票数 10
EN

Stack Overflow用户

发布于 2011-08-05 01:44:19

您可能可以使用ISNULLCOALESCE更轻松地完成此操作

代码语言:javascript
运行
复制
select top (1) 
 @theID = ISNULL(B.ID, A.ID),
 @theName = ISNULL(B.Name, A.Name),
 from B left join A on A.ID = B.ID where ...
票数 3
EN

Stack Overflow用户

发布于 2013-10-07 22:12:59

代码语言:javascript
运行
复制
DECLARE @SmallBlindSeatId INT  
DECLARE @BigBlindSeatId INT  
DECLARE @DealerSeatId INT  
DECLARE @NextTurn INT  

SELECT @DealerSeatId=( CASE WHEN BlindsInfo=1 THEN SeatId ELSE @DealerSeatId END ),
@SmallBlindSeatId=( CASE WHEN BlindsInfo=2 THEN SeatId ELSE @SmallBlindSeatId END),
@BigBlindSeatId=( CASE WHEN BlindsInfo=3 THEN SeatId ELSE @BigBlindSeatId END),
@NextTurn=( CASE WHEN NEXTTURN=1 THEN SeatId ELSE @NextTurn END)

FROM ABC WHERE TESTCASEID=1

PRINT(@DealerSeatId)

PRINT(@SmallBlindSeatId)

PRINT(@BigBlindSeatId)

PRINT (@NextTurn)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6945979

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档