SQL CASE语句会失败吗?
有没有办法让SQL中的CASE语句像C#中的CASE语句那样失败?我不想做的是下面的示例,但如果这是我唯一的选择,我想我会选择它。
示例:
@NewValue =
CASE
WHEN @MyValue = '1' THEN CAST(@MyValue AS int)
WHEN @MyValue = '2' THEN CAST(@MyValue AS int)
ELSE NULL
END
编辑:
我正在使用SQL Server。
解决方案
回答您的特定问题:不,不能。
例如,请参阅MySQL documentation for CASE。每个WHEN
都必须有一个THEN result
,这是无法避免的。THEN
未标记为可选。这同样适用于我使用过的所有其他RDBMS。
这里还有一个示例:Sql Server's CASE expression
您已经有一个很好的替代方法,可以作为评论发布,所以我在此不再重复。
相关文章