基于其他行排除行(SQL)
发布时间:2020-05-24 17:56:28 所属栏目:MsSql 来源:互联网
导读:说我有这样的查询: SELECT *FROM TABLE 它返回: TABLEID | DATA | VAL===============01 | ABCD | 101 | DEFG | 202 | FGHI | 302 | HIJK | 203 | JKLM | 303 | LMNO | 404 | NOPQ | 004 | PQRS | 1 目前我有一个查询尝试只找到这样
|
说我有这样的查询: 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)) (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- sql-server – 无法通过SQL Server Express Mana
- 如何在Sql中创建100年的日历表
- sqlserver中根据字符分割字符串的最好的写法分享
- SQL Server一些文件未注册导致mssql表文件无法找
- SQL Server生成查询的模糊匹配字符串
- SQL Server 使用sp_xml_preparedocument处理XML文
- sql-server – 为什么查询导致溢出到tempdb?
- sql – Postgres:使用ARRAY_AGG和HAVING(而不是
- 如何在Sql Server 2008全文搜索中忽略html标记
- sql-server – 如何控制用户可以解密SQL Server对
热点阅读
