簡體   English   中英

基於其他行排除行(SQL)

[英]Exclude rows based on other rows (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","2","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, 2, 3))

你可以使用減號運算符。

偽查詢

select everything
from tables
where id in ( select id from table minus select id from table where val is bad )

你可以試試像

SELECT *
FROM TABLE
WHERE TABLE.ID NOT IN(
    SELECT ID
    FROM TABLE
    WHERE TABLE.VAL < '1'
    OR TABLE.VAL > '3'
)

這是另一種替代方案,它將通過TBL一次,聚合,並使用找到的ID,從TBL中檢索數據

SELECT *
WHERE ID IN
(
    SELECT
       ID,
       CASE WHEN val in (1,2,3) THEN 1 ELSE 0 END Test
    FROM TBL
    GROUP BY ID
    HAVING MIN(val) = 1
)

對於多列鍵,作為上述IN表單的替代,您可以使用JOIN表單。

SELECT T.*
FROM (
    SELECT
       Company, OrderNumber,
       CASE WHEN val in (1,2,3) THEN 1 ELSE 0 END Test
    FROM TBL
    GROUP BY Company, OrderNumber
    HAVING MIN(val) = 1
    ) KEEP
INNER JOIN TBL T ON T.Company = KEEP.Company and T.OrderNumber=KEEP.OrderNumber

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM