加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – SQL Case Statment可以通过吗?

发布时间:2020-12-12 08:48:45 所属栏目:MsSql教程 来源:网络整理
导读:有没有办法使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中的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结果,而且没有办法. THEN没有标记为可选.同样适用于我所使用的所有其他RDBMS.

这是另一个例子:Sql Server’s CASE expression

你已经有一个很好的替代方法来发表评论,所以我不会在这里重复.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读