我想在使用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 ...将这些变量放入其中的正确位置/方法是什么?
发布于 2011-08-05 02:05:00
你所举的例子应该是有效的。您可以从case语句中为变量赋值。只要假设整个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您能告诉我们您得到的具体错误是什么吗?
发布于 2011-08-05 01:44:19
您可能可以使用ISNULL或COALESCE更轻松地完成此操作
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 ...发布于 2013-10-07 22:12:59
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)https://stackoverflow.com/questions/6945979
复制相似问题