Присвоить переменную T-SQL из оператора CASE - PullRequest
7 голосов
/ 04 августа 2011

Я бы хотел назначить некоторые переменные внутри запроса, который использует операторы 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 ...

Какое правильное место / способ вставить туда эти переменные?

Ответы [ 3 ]

9 голосов
/ 04 августа 2011

Пример, который вы дали, должен работать. Вы можете назначить переменные из оператора 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

Можете ли вы сказать нам, какие конкретно ошибки вы получаете?

3 голосов
/ 04 августа 2011

Возможно, вы могли бы сделать это проще, используя 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 ...
1 голос
/ 07 октября 2013
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)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...