T-SQL中的case语句中断

| 在mssql中的case语句中可以使用break命令吗? 因为条件已验证为表达式“ 0”,所以无需进行下一个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
    
已邀请:
        您不必使用a2,因为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
    
        这是事务性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
只有ever6ѭ     
        这不是必需的。
THEN
有效地充当返回或中断,因此该语句是短路的。     

要回复问题请先登录注册