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)的所有记录 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |