微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何知道 WHERE 语句中有多少条件符合其标准?

如何解决如何知道 WHERE 语句中有多少条件符合其标准?

假设我们有以下 sql 语句。

SELECT ID
FROM table1
WHERE P1 = P1 AND (P2 = X OR P3 = Y OR P4 = Z)

如果括号中的至少两个条件满足其条件,则此语句应返回结果,但我不知道如何编写给出这种结果的语句。提前致谢。

解决方法

对返回 CASE1 的每个条件使用 0 表达式并添加它们:

SELECT ID 
FROM table1 
WHERE P1 = P1 
  AND CASE WHEN P2 = X THEN 1 ELSE 0 END +
      CASE WHEN P3 = Y THEN 1 ELSE 0 END +
      CASE WHEN P4 = Z THEN 1 ELSE 0 END >= 2

这可以针对更多条件进行扩展。

,

简单地说,我们可以将您的 WHERE 子句扩展如下:

SELECT ID
FROM table1
WHERE P1 = P1 AND (
                  P2 = X AND P3 = Y OR
                  P2 = X AND P4 = Z OR
                  P3 = Y and P4 = Z);

根据您的数据及其背后的逻辑,可能可以进一步简化上述内容。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。