在T-SQL中的case语句中
发布时间:2020-12-12 06:43:28 所属栏目:MsSql教程 来源:网络整理
导读:可以在mssql的case语句中使用break命令吗? 因为条件验证表达式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_mikt
可以在mssql的case语句中使用break命令吗?
因为条件验证表达式GO,而不是做下一个CASE的转换. 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 解决方法您不应该使用中断,因为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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容