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

in与exists和not in 与 not exists的区别

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

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

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

看不清楚,换张图片

免费获取短信验证码

in与exists和not in 与 not exists的区别

in与exists和not in 与 not exists的区别

in 与 exists:

  外表大,用IN;内表大,用EXISTS;

  原理:

  用in:外表使用了索引,直接作hash连接;

  用exists:内表使用了索引,外表作loop循环再进行匹配;

 

not in与not exists:

  性能:not in不走索引,所以一般都用not exists;

  区别:还有一点区别就是,not in字段为null的不进行筛选出来;而使用not exists即可;

  这也就是说有时定义字段,用not null比较好了,这样也能避免not in查询出错。

 

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 不返回结果集为真)

  

免责声明:

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

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

in与exists和not in 与 not exists的区别

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

下载Word文档

猜你喜欢

in与exists和not in 与 not exists的区别

1、in 与 exists:   外表大,用IN;内表大,用EXISTS;   原理:   用in:外表使用了索引,直接作hash连接;   用exists:内表使用了索引,外表作loop循环再进行匹配;
in与exists和not in 与 not exists的区别
2022-01-25

sql中exists和in的区别

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

MySQL中in和exists区别详解

一、提前准备 为了大家学习方便,我在这里面建立两张表并为其添加一些数据。 一张水果表,一张供应商表。 水果表 fruits表f_idf_namef_pricea1apple5a2appricot2b1blackberry10b2berry8
2022-05-30

MySQL关键字IN与EXISTS的使用与区别详解

目录1. IN & NOT IN1.1 基本使用1.2 工作原理1.2.1 静态值列表的 IN 语句1.2.2 子查询的 IN 语句1.3 相关优化2. EXISTS & NOT EXISTS2.1 基本使用2.2 工作原理2.3 相关优化
MySQL关键字IN与EXISTS的使用与区别详解
2024-09-05

SQL 中的 IN 与 EXISTS:了解性能和用法

mysql 中的 in 与 exists:实例和描述在 mysql 中,in 和 exists 都用于查询中,以根据子查询中是否存在行来过滤数据。然而,它们的工作方式不同,在它们之间进行选择会影响查询性能。让我们通过解释和实践示例来分解它们
SQL 中的 IN 与 EXISTS:了解性能和用法
2024-09-14

mysql查询条件not in 和 in的区别及原因说明

先写一个SQLSELECT DISTINCT from_id FROM cod WHERE cod.from_id NOT IN (37, 56, 57)今天在写SQL的时候,发现这个查的结果不全,少了NULL值的情况,not in 的时候
2022-05-30

编程热搜

目录