SQL CASE语句会失败吗?

2022-03-03 00:00:00 case-statement sql-server

有没有办法让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

您已经有一个很好的替代方法,可以作为评论发布,所以我在此不再重复。

相关文章