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



假设我们有以下SQL语句。

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

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

对返回10的每个条件使用CASE表达式,并将它们相加:

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);

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

最新更新