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语句的区别。

相关推荐
程序猿小D1 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
发仔1236 小时前
Oracle与MySQL核心差异对比
mysql·oracle
叁沐8 小时前
MySQL 08 详解read view:事务到底是隔离的还是不隔离的?
mysql
wkj0018 小时前
navicate如何设置数据库引擎
数据库·mysql
ladymorgana8 小时前
【Spring Boot】HikariCP 连接池 YAML 配置详解
spring boot·后端·mysql·连接池·hikaricp
kk在加油11 小时前
Mysql锁机制与优化实践以及MVCC底层原理剖析
数据库·sql·mysql
合作小小程序员小小店12 小时前
web网页开发,在线%ctf管理%系统,基于html,css,webform,asp.net mvc, sqlserver, mysql
mysql·sqlserver·性能优化·asp.net·mvc
JosieBook12 小时前
【Java编程动手学】Java常用工具类
java·python·mysql
hello 早上好12 小时前
MsSql 其他(2)
数据库·mysql
高压锅_122012 小时前
SQLAlchemy数据库连接密码特殊字符处理完全指南
数据库·mysql·django·sqlalchemy