sql - 选择与列表中所有项目匹配的行组

标签 sql sql-server tsql relational-division

假设我有两个表:

汽车 – 汽车列表

carname | modelnumber | ...

passedtest – 包含汽车通过的每项测试:

id | carname | testtype | date | ...
1  | carA    | A        | 2000 |
2  | carB    | C        | 2000 |
3  | carC    | D        | 2001 |
4  | carA    | C        | 2002 |

现在,我如何从 passedtest 表中选择一辆通过所有测试(A、B、C、D)的汽车?

我尝试了 IN 语句,但它也匹配通过了一项测试的汽车。我正在寻找一个语句来匹配列表中所有行的所有值。

最佳答案

这个怎么样?

SELECT carname
FROM PassedTest
GROUP BY carname
HAVING COUNT(DISTINCT testtype) = 4

您还可以将其用作内部语句,从 cars 表中获取信息:

SELECT *
FROM cars
WHERE carname IN (
    SELECT carname
    FROM PassedTest
    GROUP BY carname
    HAVING COUNT(DISTINCT testtype) = 4
)

关于sql - 选择与列表中所有项目匹配的行组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15977126/

相关文章:

mysql - 相等和相等的 SQL 顺序是否相等?

sql-server - FOR XML 无法序列化节点的数据,因为它包含 XML 中不允许的字符 (0x0001)

sql-server - 如何使用tsql将表输出到txt文件?

sql - 使用 t-sql 进行透视转换

mysql - 如何更新以特定文本结尾的列?

sql - Oracle Trigger If 语句条件以某种方式未被满足?

mysql - 在 MySQL 中将表汇总并拆分为不同的表

sql - 根据自动增量列插入列值

sql - SQL Server中如何生成随机数据

sql - 在 sql 中按 IS NOT NULL AND 过滤