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

SQL在WHERE IN子句中使用CASE语句

发布时间:2020-12-12 16:28:04 所属栏目:MsSql教程 来源:网络整理
导读:在条款中使用案例是否可行? 这样的事情 DECLARE @Status VARCHAR(50); SET @Status='published'; SELECT * FROM Product P WHERE P.Status IN (CASE WHEN @Status='published' THEN (1,3) WHEN @Status='standby' THEN (2,5,9,6) WHEN @Status='deleted' THE
在条款中使用案例是否可行?
这样的事情
DECLARE @Status VARCHAR(50);
 SET @Status='published';

 SELECT * FROM Product P    
 WHERE P.Status IN (CASE WHEN @Status='published' THEN (1,3)
                                   WHEN @Status='standby' THEN (2,5,9,6)
                                   WHEN @Status='deleted' THEN (4,8,10)
                                   ELSE (1,3)
                                   END)

此代码给出错误:’,’附近的错误语法.

解决方法

不,你不能用这种情况.但你可以做
SELECT * FROM Product P    
WHERE @Status='published' and P.Status IN (1,3)
or @Status='standby' and P.Status IN  (2,6)
or @Status='deleted' and P.Status IN (4,10)
or P.Status IN (1,3)

BTW你可以减少到

SELECT * FROM Product P    
WHERE @Status='standby' and P.Status IN (2,3)

既然或P.Status IN(1,3)也给出了@ Status =’published’和P.Status IN(1,3)的所有记录

(编辑:李大同)

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

    推荐文章
      热点阅读