说我有这样的查询:
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","3") ) = 0
这可行吗?还有更好的选择吗?
谢谢!
解决方法
使用:
SELECT * FROM TABLE a WHERE a.val IN (1,2,3) AND NOT EXISTS(SELECT NULL FROM TABLE b WHERE b.id = a.id AND b.val NOT IN (1,3))