假设我有这样的查询:
SELECT *
FROM TABLE
它返回这个:
TABLE
ID | DATA | VAL
===============
01 | ABCD | 1
01 | DEFG | 2
02 | FGHI | 3
02 | HIJK | 2
03 | JKLM | 3
03 | LMNO | 4
04 | NOPQ | 0
04 | PQRS | 1
目前我有一个查询,它试图只找到像这样的好值,但它有缺陷,因为在其他行中包含错误 VAL 的 ID,这不是我想要的。
SELECT *
FROM TABLE
WHERE TABLE.VAL IN ("1","2","3")
会返回这个(缺少 LMNO 和 PQRS):
TABLE
ID | DATA | VAL
===============
01 | ABCD | 1
01 | DEFG | 2
02 | FGHI | 3
02 | HIJK | 2
03 | JKLM | 3
04 | NOPQ | 0
但是,我只想要 ID 没有错误值的行。所以,01 和 02 很好,因为它们的所有行都有很好的结果。03 和 04 不好,因为它们被其他行中的坏结果污染了。
我可以像这样将结果带入并在软件中以这种方式处理它,但似乎这应该可以通过数据库实现,并且作为一般规则,在数据库上执行比在软件中更好(你知道,这就是他们在那里的目的......)
我能想到的最好的是:
SELECT *
FROM TABLE
WHERE COUNT( SELECT ID
FROM TABLE
WHERE TABLE.VAL NOT IN ("1","2","3")
) = 0
这可行吗?有更好的选择吗?
谢谢!