`

not exists用法

 
阅读更多
exists : 强调的是是否返回结果集,不要求知道返回什么, 比如:
  select name from student where sex = 'm' 
  and mark exists(select 1 from grade where ...) 
  ,只要exists引导的子句有结果集返回,那么exists这个条件就算成立了,
  大家注意返回的字段始终为1,如果改成“select 2 from grade where ...”,
  那么返回的字段就是2,这个数字没有意义。
  所以exists子句不在乎返回什么,而是在乎是不是有结果集返回。
而 exists 与 in 最大的区别在于 in引导的子句只能返回一个字段,比如:
  select name from student where sex = 'm' 
  and mark in (select 1,2,3 from grade where ...) 
,in子句返回了三个字段,这是不正确的,
exists子句是允许的,但in只允许有一个字段返回,
在1,2,3中随便去了两个字段即可。
而not exists 和not in 分别是exists 和 in 的 对立面。
exists (sql 返回结果集为真) 
not exists (sql 不返回结果集为真)

下面详细描述not exists的过程:

如下:
表A
ID NAME 
1   A1
2   A2
3   A3

表B
ID AID NAME
1   1     B1
2   2     B2 
3   2     B3
表A和表B是1对多的关系 A.ID => B.AID

SELECT ID,NAME FROM A WHERE EXISTS 
(SELECT * FROM B WHERE A.ID=B.AID)
执行结果为
1 A1
2 A2
原因可以按照如下分析
SELECT ID,NAME FROM A WHERE 
EXISTS (SELECT * FROM B WHERE B.AID=1)
--->SELECT * FROM B WHERE B.AID=1
--有值返回真所以有数据

SELECT ID,NAME FROM A WHERE 
EXISTS (SELECT * FROM B WHERE B.AID=2)
--->SELECT * FROM B WHERE 
--B.AID=2有值返回真所以有数据

SELECT ID,NAME FROM A WHERE 
EXISTS (SELECT * FROM B WHERE B.AID=3)
--->SELECT * FROM B WHERE 
--B.AID=3无值返回真所以没有数据

NOT EXISTS 就是反过来
SELECT ID,NAME FROM A WHERE 
NOT EXIST (SELECT * FROM B WHERE A.ID=B.AID)
执行结果为
3 A3
=========================================
EXISTS = IN,意思相同不过语法上有点点区别,
好像使用IN效率要差点,应该是不会执行索引的原因
SELECT ID,NAME FROM A  
WHERE ID IN (SELECT AID FROM B)

NOT EXISTS = NOT IN ,意思相同不过语法上有点点区别
SELECT ID,NAME FROM A WHERE ID 
NOT IN (SELECT AID FROM B)
 有时候我们会遇到要选出某一列不重复,
 某一列作为选择条件,其他列正常输出的情况.

如下面的表table:

Id  Name  Class Count  Date
 1   苹果    水果    10     2011-7-1
 1   桔子    水果    20     2011-7-2
 1   香蕉    水果    15     2011-7-3
 2   白菜    蔬菜    12     2011-7-1
 2   青菜    蔬菜    19     2011-7-2

如果想要得到下面的结果:(Id唯一,Date选最近的一次)
1   香蕉    水果    15     2011-7-3
2   青菜    蔬菜    19     2011-7-2

正确的SQL语句是:
SELECT Id,Name,Class,Count,Date
FROM table t
WHERE (NOT EXISTS
          (SELECT Id, Name,Class,Count,Date FROM table
         WHERE Id = t.Id AND Date > t.Date))

如果用distinct,得不到这个结果, 因为distinct是作用与所有列的

SELECT DISTINCT Id,Name,Class,Count,Date FROM table

结果是表table的所有不同列都显示出来,如下所示:
 1   苹果     水果    10     2011-7-1
 1   桔子    水果    20     2011-7-2
 1   香蕉    水果    15     2011-7-3
 2   白菜    蔬菜    12     2011-7-1
 2   青菜    蔬菜    19     2011-7-2

如果用Group by也得不到需要的结果,因为Group by 
要和聚合函数共同使用,所以对于Name,Class和Count列
要么使用Group by,要么使用聚合函数. 如果写成

SELECT Id,Name,Class,Count,MAX(Date)
FROM table
GROUP BY Id,Name,Class,Count

得到的结果是
 1   苹果     水果    10    2011-7-1
 1   桔子    水果    20     2011-7-2
 1   香蕉    水果    15     2011-7-3
 2   白菜    蔬菜    12     2011-7-1
 2   青菜    蔬菜    19     2011-7-2

如果写成

SELECT Id, MAX(Name),MAX(Class),MAX(Count),MAX(Date)
FROM table GROUP BY Id

得到的结果是:
 1   香蕉    水果    20     2011-7-3
 2   青菜    蔬菜    19     2011-7-2

如果用in有时候也得不到结果,(有的时候可以得到,如果Date都不相同
(没有重复数据),或者是下面得到的Max(Date)只有一个值)

SELECT DISTINCT Id,Name,Class,Count,Date FROM table

WHERE (Date IN
          (SELECT MAX(Date)
         FROM table
         GROUP BY Id))

得到的结果是:(因为MAX(Date)有两个值2011-7-2,2011-7-3)
 1   桔子    水果    20     2011-7-2
 1   香蕉    水果    15     2011-7-3
 2   青菜    蔬菜    19     2011-7-2

注意in只允许有一个字段返回
有一种方法可以实现:
SELECT Id, Name, Class, COUNT, Date
FROM table1 t
WHERE (Date =
          (SELECT MAX(Date)
         FROM table1
         WHERE Id = t .Id))

 

分享到:
评论

相关推荐

    sql exists和not exists用法

    ### SQL EXISTS 和 NOT EXISTS 的用法详解 在SQL查询中,`EXISTS`与`NOT EXISTS`是非常实用的子查询操作符,它们主要用于检测是否存在满足一定条件的数据行。相较于`IN`、`NOT IN`等操作,`EXISTS`与`NOT EXISTS`...

    exists用法说明.doc

    ### NOT EXISTS用法 `NOT EXISTS`子句与`EXISTS`相反,它用于查找那些不满足内部查询条件的记录。其基本形式是: ```sql SELECT column1, column2, ... FROM table1 WHERE NOT EXISTS (SELECT 1 FROM table2 WHERE...

    exists SQL用法详解、exists和not exists的常用示例

    在SQL查询中,`EXISTS`和`NOT EXISTS`是两个非常重要的子查询操作符,它们主要用于判断子查询是否返回结果。本篇文章将详细介绍这两个关键字的用法,并通过实例进行解析。 首先,`EXISTS`的语法是:主查询中的条件...

    sql in,exists,not in,not exists区别

    SQL 中 IN、EXISTS、NOT IN、NOT EXISTS 的区别 IN、EXISTS、NOT IN、NOT EXISTS 是 SQL 中四种常用的条件判断运算符,它们之间的区别主要体现在使用场景、执行效率和语法结构上。 IN IN 是一种条件判断运算符,...

    EXISTS_和_NOT_EXISTS

    在SQL查询中,`EXISTS` 和 `NOT EXISTS` 子句是两个非常重要的条件运算符,用于在数据检索时筛选满足特定条件的记录。它们主要用于子查询,帮助我们检查主查询的结果集是否存在匹配的子查询结果。让我们深入探讨这两...

    sql case when exists not exists in not in

    在SQL查询中,`CASE WHEN`、`EXISTS`、`NOT EXISTS`以及`IN`和`NOT IN`是常用的操作符,它们用于处理复杂的条件判断和数据筛选。这些概念对于理解和编写高效的SQL语句至关重要,尤其是在数据分析和数据库管理中。 `...

    关于《数据库系统概论》第5版中not exists相关使用的理解及记录

    关于《数据库系统概论》第5版中not exists相关使用的理解及记录 关于SQL中not exists的使用学习了两三遍,一直都是理解的很朦胧,今天重新做了一下相关题目,有了新的认识,赶紧记录下来,如下。 题目涉及《数据库...

    sqlserver exists,not exists的用法

    在SQL Server中,`EXISTS` 和 `NOT EXISTS` 是两个非常重要的子查询操作符,它们用于检查子查询是否返回任何行。理解这两个操作符的用法对于编写高效的查询至关重要。 1. `EXISTS` 操作符: `EXISTS` 用于测试子...

    sql中exists的用法

    SQL 中 EXISTS 的用法简介 exists 是 SQL 中最常用的子查询操作符之一,用于检测子查询是否返回至少一个记录。exists 的使用场景非常广泛,包括对多表之间的关系进行查询、检测记录的存在性等。 在 SQL 中,exists...

    SQL中exists的用法[借鉴].pdf

    NOT EXISTS 的用法 NOT EXISTS 是 EXISTS 的反面,它用于判断子查询是否不返回记录。 例如:`SELECT ID, NAME FROM A WHERE NOT EXISTS (SELECT * FROM B WHERE A.ID=B.AID)` 在上面的示例中,NOT EXISTS 子句...

    MySQL中的in,exists,not in,not exists查询过程对比及结论

    MySQL优化之in,exists,not in,not exists的区别in与existsin查询过程结论:exists查询过程:结论:not in与not existsnot in查询过程:结论:not exists查询过程:结论: 首先我们使用两个用户表作为实例 insert ...

    oracle数据库关于exists使用

    - **内层Exists**: `NOT EXISTS(SELECT * FROM sc WHERE cno = course.cno AND sno = student.sno)` 检查是否有学生没有选修某门课程。这里的关键是,对于每一个 `course` 和 `student` 的组合,如果找不到相应的...

    mysql exists与not exists实例详解

    MySQL中的`EXISTS`和`NOT EXISTS`是两种常用的子查询操作符,它们在数据库查询中扮演着重要的角色,特别是在处理复杂的数据关联和过滤时。本文将深入探讨这两种操作符的用法、区别以及在实际应用中的性能差异。 ...

    mssql和sqlite中关于if not exists 的写法

    在sql语名中,if not exists 即如果不存在,if exists 即如果存在。 下面学习下二者的用法。 a,判断数据库不存在时 代码如下:if not exists(select * from sys.databases where name = ‘database_name’) b,...

    sql 学习

    -- NOT EXISTS 用法 SELECT * FROM kj_dept WHERE NOT EXISTS (SELECT * FROM kj_dept_info WHERE kj_dept.dept_id = kj_dept_info.dept_id AND dept_id=XXX) -- 外连接加条件判断 SELECT * FROM kj_dept d ...

    SQL语句集锦.rar

    工作中常用的SQL + 超复杂SQL ...not exists用法实例.txt ORACLE编程实用手册.doc patindex的用法.txt rename存储过程.txt replace.txt rowcount.txt rowcount精华.txt stuff.txt substring和rtrim.txt unionall.txt

    oracle中not exists对外层查询的影响详解

    首先,让我们回顾`NOT EXISTS`的基本用法。当我们在一个查询中使用`NOT EXISTS`时,它会检查子查询中的条件是否不成立。如果子查询返回任何记录,那么`NOT EXISTS`子句就会为假,导致外层查询的相应行被排除。反之,...

Global site tag (gtag.js) - Google Analytics