SQL之CASE WHEN用法进阶——where语句后跟case语句(二)

SQL之CASE WHEN基础用法详解(一)

SQL之CASE WHEN用法进阶——where语句后跟case语句(二)

SQL之CASE WHEN用法进阶——Update语句使用case更新、数据对比(三)

 

在where后面使用case when的说明
报错语句

select * from A, B where B.name in CASE when A.id = 0 then ('aaa', 'bbb') when A.id = 1 then ('bbb', 'ccc') when A.id = 2 then ('ccc', 'ddd') END


正确写法:将B.name in 放到CASE END 中

select * from A, B where CASE when A.id = 0 then B.name in ('aaa', 'bbb') when A.id = 1 then B.name in ('bbb', 'ccc') when A.id = 2 then B.name in ('ccc', 'ddd') END



补充:当使用 B.name = 时,将不会出现以上问题,也就是如下写法也正确

select * from A, B where B.name = CASE when A.id = 0 then 'aaa' when A.id = 1 then 'bbb' when A.id = 2 then 'ccc' END




__EOF__

本文作者Ray
本文链接https://www.cnblogs.com/Rui6/p/15708523.html
关于博主:分享、记录日常遇到的问题合集!
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   大白菜!  阅读(2959)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示