mysql中的EXISTS和NOT EXISTS使用详解

本文来编写一个实例说下mysql中的EXISTS和NOT EXISTS使用详解

文章目录


exists用法

exists:

  • 如果括号内子查询语句返回结果不为空,说明where条件成立,就会执行主SQL语句。
  • 如果括号内子查询语句返回结果为空,说明where条件不成立,就不会执行主SQL语句。

not exists与exists相反

  • 如果括号内子查询语句结果为空,说明表示where条件成立,就会执行主SQL语句。
  • 如果括号内子查询语句结果不为空,说明表示where条件不成立,就不会执行主SQL语句。

SQL中in, not in, exists, not exists的区别

in

  • 确定给定的值是否与子查询或者列表中的值匹配
  • in关键字选择与列表中任意一个值匹配的行
  • in关键字之后的项目必须用逗号隔开,并且括在括号中

not in

  • 通过not in关键字引入的子查询也返回一列零值或更多值

exists

  • 指定一个子查询,检测行的存在
  • 相当于两个集合的交集
  • exists后面可以是整句的查询语句 ,in后面只能是单列查询语句

not exists

  • 相当于两个集合的差集

exists和not exists返回的结果类型是Boolean

  • 如果子查询包含行:
  • exists返回TRUE
  • not exists返回FALSE

exists与in的区别

  • in只能返回一个字段值。
  • exists强调是否返回结果集,不要求知道返回什么,exists允许返回多个字段。
  • exists适合外表的结果集小的情况。
  • in适合内外表都很大的情况。

使用实例

创建2个表结构


语句对比

sql 复制代码
select count(1) from orders o where o.user_id in(select u.id from users u);


select count(1) from orders o where exists (select 1 from users u where u.id = o.user_id);

1.in:先查询in后面的users表,然后再去orders中过滤,也就是先执行子查询,结果出来后,再遍历主查询,遍历主查询是根据user_id和id相等查询的。

即查询users表相当于外层循环,主查询就是外层循环

小结:in先执行子查询,也就是in()所包含的语句。子查询查询出数据以后,将前面的查询分为n次普通查询(n表示在子查询中返回的数据行数)

2.exists:主查询是内层循环,先查询出orders,查询orders就是外层循环,然后会判断是不是存在order_id和 users表中的id相等,相等才保留数据,查询users表就是内层循环

这里所说的外层循环和内层循环就是我们所说的嵌套循环,而嵌套循环应该遵循"外小内大"的原则,这就好比你复制很多个小文件和复制几个大文件的区别

小结:如果子查询查到数据,就返回布尔值true;如果没有,就返回布尔值false。返回布尔值true则将该条数据保存下来,否则就舍弃掉。也就是说exists查询,是查询出一条数据就执行一次子查询

结论

小表驱动大表。

in适合于外表大而内表小的情况,exists适合于外表小而内表大的情况。


本文小结

本文介绍了mysql中的EXISTS和NOT EXISTS使用,以及与in语句的区别。

相关推荐
在未来等你2 小时前
SQL进阶之旅 Day 21:临时表与内存表应用
sql·mysql·postgresql·database·temporary-table·memory-table·sql-optimization
小Tomkk4 小时前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
寒山李白6 小时前
MySQL复杂SQL(多表联查/子查询)详细讲解
sql·mysql·子查询·多表联查
冰橙子id6 小时前
centos7编译安装LNMP架构
mysql·nginx·架构·centos·php
玛奇玛丶6 小时前
面试官:千万级订单表新增字段怎么弄?
后端·mysql
天天摸鱼的java工程师8 小时前
从被测试小姐姐追着怼到运维小哥点赞:我在项目管理系统的 MySQL 优化实战
java·后端·mysql
Clang's Blog8 小时前
一键搭建 WordPress + MySQL + phpMyAdmin 环境(支持 PHP 版本选择 & 自定义配置)
数据库·mysql·php·wordpr
异常君8 小时前
高并发数据写入场景下 MySQL 的性能瓶颈与替代方案
java·mysql·性能优化
RestCloud8 小时前
如何通过ETLCloud实现跨系统数据同步?
数据库·数据仓库·mysql·etl·数据处理·数据同步·集成平台
程序员岳焱9 小时前
Java 与 MySQL 性能优化:MySQL 慢 SQL 诊断与分析方法详解
后端·sql·mysql