gpt4 book ai didi

sql - 根据其他行排除行 (SQL)

转载 作者:行者123 更新时间:2023-12-01 09:37:44 25 4
gpt4 key购买 nike

假设我有一个这样的查询:

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

关于sql - 根据其他行排除行 (SQL),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4823353/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com