сломать в случае заявление в T-SQL - PullRequest
7 голосов
/ 27 мая 2011

Возможно ли использовать команду break в операторе case в mssql?

Поскольку проверяется условие, что выражение GO вместо выполнения следующего перехода CASE.ssip_miktar равен 5, ssip_teslim_miktar равен 0, а S74MIKTAR равен 5

update set ssip_teslim_miktar= ssip_teslim_miktar+
CASE WHEN ssip_miktar<@S74MIKTAR AND ssip_teslim_miktar=0 THEN @S74MIKTAR-ssip_miktar
WHEN ssip_miktar<@S74MIKTAR AND ssip_teslim_miktar>0 THEN @S74MIKTAR-(ssip_miktar+ssip_teslim_miktar) 
WHEN ssip_miktar=@S74MIKTAR AND ssip_teslim_miktar=0 THEN @S74MIKTAR 
WHEN ssip_miktar=@S74MIKTAR AND ssip_teslim_miktar>0 THEN @S74MIKTAR-ssip_teslim_miktar
 WHEN ssip_miktar>@S74MIKTAR AND ssip_teslim_miktar=0 THEN @S74MIKTAR
 WHEN ssip_miktar>@S74MIKTAR AND ssip_teslim_miktar>0 THEN @S74MIKTAR  
END,
@S74MIKTAR=@S74MIKTAR-CASE 
         WHEN  ssip_miktar<@S74MIKTAR AND ssip_teslim_miktar=0 THEN @S74MIKTAR-ssip_miktar
         WHEN  ssip_miktar<@S74MIKTAR AND ssip_teslim_miktar>0 THEN @S74MIKTAR-(ssip_miktar+ssip_teslim_miktar)
         WHEN  ssip_miktar=@S74MIKTAR AND ssip_teslim_miktar=0 THEN @S74MIKTAR
         WHEN  ssip_miktar=@S74MIKTAR AND ssip_teslim_miktar>0 THEN @S74MIKTAR-ssip_teslim_miktar
         WHEN  ssip_miktar>@S74MIKTAR AND ssip_teslim_miktar=0 THEN @S74MIKTAR
         WHEN  ssip_miktar>@S74MIKTAR AND ssip_teslim_miktar>0 THEN @S74MIKTAR
                     ELSE 0
      END
where ssip_teslim_miktar<ssip_miktar

Ответы [ 3 ]

8 голосов
/ 27 мая 2011

Вам не нужно использовать break, потому что операторы SQL Case не допускаются.

DECLARE @x int

SET @x = 0

SELECT CASE
    WHEN @x = 0 THEN 'zero'     -- Only this line of the expression is evaluated
    WHEN @x <> 0 THEN 'not-zero'
    END
5 голосов
/ 27 мая 2011

Это транзакционный SQL, а не итеративный. Он не требует перерыва, потому что будет оцениваться только одно из предложений when / else.

Попробуйте следующее:

declare @test int
set @test=1
select @test = @test + 
    case 
        when 1=1 then 1
        when 2=2 then 1
        when 3=3 then 1
        when 4=4 then 1
        when 5=5 then 1
        when 6=6 then 1
        when 7=7 then 1
        when 8=8 then 1
        else 1
       end
select @test

@test только когда-либо 2

4 голосов
/ 27 мая 2011

Это не обязательно.THEN эффективно действует как возврат или разрыв, поэтому оператор замкнут.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...