我的编程空间,编程开发者的网络收藏夹
学习永远不晚

sql中exists和not exists怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

sql中exists和not exists怎么用

这篇文章主要介绍了sql中exists和not exists怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

exists:

强调的是是否有返回集,不需知道具体返回的是什么,比如:         

      SELECT*      FROMcustomer     WHERE not EXISTS (SELECT0FROMcustomer_goodsWHEREcustomer_id = 1)

只要exists引导的子句有结果集返回,这个条件就算成立。这个返回的字段始终是0,改成1,则始终返回的是1,所以exists不

在乎返回的是什么内容,只在乎是否有结果集返回。

exists 和in 的区别

 这二者最大的区别,是使用in只能返回一个字段值     

     SELECT*     FROMcustomer c     WHERE     c.id  not in (SELECTcustomer_idFROMcustomer_goodsWHEREcustomer_id = 1)

但exists允许返回多个字段。

not in 和not exists 分别为in 和exists的对立面。

exists(sql 返回结果集为真)

not exists(sql 不返回结果集为真)

not exists详细介绍:

表customer:

sql中exists和not exists怎么用

 表customer_goods:

sql中exists和not exists怎么用

二者的干系:customer_goods.customer_id = customer.id

(1) 查询:

     SELECT*     FROMcustomer c     WHERENOT EXISTS (SELECT*FROMcustomer_goodscg                WHERE                         cg.customer_id =1)

结果:

无返回结果

sql中exists和not exists怎么用

(2)查询: 

    SELECT*    FROMcustomer c    WHERENOT EXISTS (SELECT*FROMcustomer_goodscg                WHERE                          c.id =1)

结果:

sql中exists和not exists怎么用

(3)分析:

发现二者差别只是是否not exists字句查询的查询条件是否跟外面查询条件有关,如果not exists子查询只有自己本身的查询条件,这样只要子查询中有数据返回,就证明是false,结果在整体执行就无返回值;一旦跟外面的查询关联上,就能准确查出数据。

而我遇到的问题正是这个。

经过分析,我认为一旦跟外层查询关联上,就会扫描外面查询的表。而没一旦二者不添加关联关系,只会根据not exists返回是否有结果集来判断,这也是为什么一旦子查询有数据,就查不到所有的数据了。

附案例分析

来看看not exists或exists是如何用的吧。

# 学生表CREATE TABLE `Student`(    `s_id` VARCHAR(20),    `s_name` VARCHAR(20) NOT NULL DEFAULT '',    `s_birth` VARCHAR(20) NOT NULL DEFAULT '',    `s_sex` VARCHAR(10) NOT NULL DEFAULT '',    PRIMARY KEY(`s_id`));# 课程表CREATE TABLE `Course`(    `c_id`  VARCHAR(20),    `c_name` VARCHAR(20) NOT NULL DEFAULT '',    `t_id` VARCHAR(20) NOT NULL,    PRIMARY KEY(`c_id`));# 教师表CREATE TABLE `Teacher`(    `t_id` VARCHAR(20),    `t_name` VARCHAR(20) NOT NULL DEFAULT '',    PRIMARY KEY(`t_id`));# 成绩表CREATE TABLE `Score`(    `s_id` VARCHAR(20),    `c_id`  VARCHAR(20),    `s_score` INT(3),    PRIMARY KEY(`s_id`,`c_id`));# 插入学生表测试数据insert into Student values('01' , '赵雷' , '1990-01-01' , '男');insert into Student values('02' , '钱电' , '1990-12-21' , '男');insert into Student values('03' , '孙风' , '1990-05-20' , '男');insert into Student values('04' , '李云' , '1990-08-06' , '男');insert into Student values('05' , '周梅' , '1991-12-01' , '女');insert into Student values('06' , '吴兰' , '1992-03-01' , '女');insert into Student values('07' , '郑竹' , '1989-07-01' , '女');insert into Student values('08' , '王菊' , '1990-01-20' , '女');#课程表测试数据insert into Course values('01' , '语文' , '02');insert into Course values('02' , '数学' , '01');insert into Course values('03' , '英语' , '03');# 教师表测试数据insert into Teacher values('01' , '张三');insert into Teacher values('02' , '李四');insert into Teacher values('03' , '王五');#成绩表测试数据insert into Score values('01' , '01' , 80);insert into Score values('01' , '02' , 90);insert into Score values('01' , '03' , 99);insert into Score values('02' , '01' , 70);insert into Score values('02' , '02' , 60);insert into Score values('02' , '03' , 80);insert into Score values('03' , '01' , 80);insert into Score values('03' , '02' , 80);insert into Score values('03' , '03' , 80);insert into Score values('04' , '01' , 50);insert into Score values('04' , '02' , 30);insert into Score values('04' , '03' , 20);insert into Score values('05' , '01' , 76);insert into Score values('05' , '02' , 87);insert into Score values('06' , '01' , 31);insert into Score values('06' , '03' , 34);insert into Score values('07' , '02' , 89);insert into Score values('07' , '03' , 98);

题目是查询和"01"号的同学学习的课程完全相同的其他同学的信息,直接做确实有点麻烦,我们可以先做做这题:查看学了所有课程的同学的信息。

学了所有课程的同学的信息,那不就是这些同学没有一门课程没有学吗。

select * from Student st where not exists(select * from Course c where not exists(select * from Score sc where sc.c_id = c.c_id and sc.s_id = st.s_id));

sql中exists和not exists怎么用

然后我们再回过来看这题,把所有的课程换成01同学学的课程。

select * from Student st where not exists(select * from( select s2.c_id as c_id from Student s1 inner join Score s2 on s1.s_id = s2.s_id where s1.s_id = 01) t where  not exists (select * from Score sc where sc.c_id = t.c_id and sc.s_id = st.s_id and st.s_id != 01));

sql中exists和not exists怎么用

感谢你能够认真阅读完这篇文章,希望小编分享的“sql中exists和not exists怎么用”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

sql中exists和not exists怎么用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sql中exists和not exists怎么用

这篇文章主要介绍了sql中exists和not exists怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。exists:强调的是是否有返回集,不需知道具体返回的是什么,
2023-06-29

sql中exists和not exists怎么使用

在SQL中,EXISTS和NOT EXISTS是用来检查子查询是否返回结果的条件表达式。- EXISTS:如果子查询返回至少一行结果,则返回true,否则返回false。例如:```sqlSELECT * FROM table1 WHERE
2023-08-16

使用SQL中的EXISTS和NOT EXISTS的语法

SQL中的exists和not exists的用法,需要具体的代码示例在SQL中,exists和not exists是一对常用的谓词(predicate),用于判断一个子查询(subquery)是否返回了结果集。exists用于检查子查询
使用SQL中的EXISTS和NOT EXISTS的语法
2024-02-22

详细聊聊sql中exists和not exists用法

在SQL中,EXISTS和NOT EXISTS是用于判断子查询中是否存在或不存在记录的条件运算符。1. EXISTS用法:EXISTS语句用于判断子查询是否返回结果,并返回布尔值,如果子查询返回至少一条记录,则返回true,否则返回fals
2023-08-08

sql中not exists怎么使用

在SQL中,NOT EXISTS 是一个条件运算符,用于检查子查询的结果是否为空。它用于在主查询中过滤掉那些在子查询中存在的记录。使用 NOT EXISTS,你需要编写一个子查询,并在主查询中使用该条件运算符来检查子查询的结果。子查询可以是
2023-08-08

oracle中的exists 和not exists 用法详解

在Oracle中,EXISTS和NOT EXISTS是用来检查子查询是否返回任何行的条件运算符。- EXISTS:当子查询返回至少一行时,EXISTS条件返回TRUE。如果子查询没有返回任何行,则返回FALSE。- NOT EXISTS:当
2023-09-12

SQL中NOT EXISTS的使用

NOT EXISTS是SQL中的一个条件运算符,用于检查子查询的结果集是否为空。它的语法如下:```SELECT column1, column2, ...FROM table1WHERE NOT EXISTS (子查询)```子查询可以是
2023-09-22

sql中exists怎么使用

在SQL中,EXISTS是一个用于检查子查询结果是否存在的操作符。它返回一个布尔值,表示是否存在。以下是EXISTS的使用方法:1. 使用EXISTS条件:```sqlSELECT column1, column2, ...FROM tab
2023-08-08

SQL (NOT) EXISTS的用法是什么

SQL中的(NOT) EXISTS是一种条件运算符,用于检查一个子查询是否返回结果。- EXISTS:如果子查询返回至少一行结果,则返回true。它可以与WHERE子句一起使用,以根据子查询的结果过滤数据。- NOT EXISTS:如果子查
2023-10-20

oracle中的not exists怎么使用

在Oracle中,NOT EXISTS是一个用于查询的条件表达式,用于检查一个子查询是否为空。如果子查询返回的结果集为空,则NOT EXISTS条件返回TRUE,否则返回FALSE。NOT EXISTS的语法如下:```SELECT col
2023-08-23

sql查询exists怎么用

exists 操作符检查子查询中是否存在记录,返回布尔值 true 或 false。用法:select column_list from table_name where exists (subquery); 优点:效率、易用性和可读性。注
sql查询exists怎么用
2024-05-30

sql中exists用法

exists 是 sql 中的一个布尔运算符,用于检查子查询是否返回任何行。它与子查询一起使用,子查询返回布尔值以确定是否存在满足条件的行。exists 主要用于确定与主表特定行匹配的行是否存在,例如查找关联表中存在匹配行的记录、检查表中是
sql中exists用法
2024-05-15

sql中exists和in的区别

exists和in都是检查子查询结果的sql谓词,但语法和用法不同。exists检查是否存在任何结果,in检查特定列中的值是否包含在子查询中。exists在检查单个记录时更有效,in在检查多个记录时更有效。exists子查询范围是整个表,i
sql中exists和in的区别
2024-05-15

SQL 中 EXISTS 用法详解

EXISTS 是 SQL 中的一个逻辑运算符,用于判断一个子查询是否返回了结果。它返回一个布尔值,如果子查询返回至少一行结果,则返回 true,否则返回 false。EXISTS 的一般用法如下:```SELECT column1, col
2023-10-08

sql中exists具体用法

exists 子查询用于检查外层查询中的行是否存在匹配记录,用法如下:包含在 select 语句的 where 子句中。返回布尔值 true (存在匹配) 或 false (不存在匹配)。内层查询中包含匹配条件,用于确定内层表中是否存在与外
sql中exists具体用法
2024-05-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录