基于其他行排除行(SQL)

前端之家收集整理的这篇文章主要介绍了基于其他行排除行(SQL)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
说我有这样的查询
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))
原文链接:https://www.f2er.com/mssql/79500.html

猜你在找的MsSQL相关文章