写点什么

MyBatis 中的条件查询!关键字 exists 用法的详细解析

发布于: 3 小时前
MyBatis中的条件查询!关键字exists用法的详细解析

exists 用法

  • exists:

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

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

  • not exists: 与 exists 相反

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

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

  • exists 与 in 的区别:

  • in 只能返回一个字段值

  • exists 强调是否返回结果集,不要求知道返回什么,exists 允许返回多个字段

  • exists 的效率一般优于 in:

  • 使用 exists,Oracle 首先会检查主查询,然后运行子查询直到找到第一个匹配项

  • 使用 in 子查询时,首先会执行子查询,并将获得的结果列表放在一个加了索引的临时表中

  • exists 的效率优于 distinct:

  • 当提交一对多表信息查询时,就可以避免在 select 中使用 distinct

  • 因为 RDBMS 核心模块将在子查询的条件一旦满足后,立即返回结果,所以自带去重.以下两组 SQL 语句等价:


      SELECT distinct dept_no, dept_name from dept D, EMP E WHERE D.dept_no = E.dept_no;
复制代码


      SELECT dept_no, dept_name from dept D WHERE EXISTS (SELECT 1 from emp E WHERE E.dept_no = D.dept_no);
复制代码


- **exists适合外表的结果集小的情况**- **in适合内外表都很大的情况**
复制代码

使用示例

  • exists:


SELECT ID,NAME FROM A WHERE EXISTS(SELECT * FROM B WHERE A.ID = B.AID)
复制代码


  • SQL 语句分解:


SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=1) --->SELECT * FROM B WHERE B.AID=1有值返回TRUE所以有数据 
SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=2) --->SELECT * FROM B WHERE B.AID=2有值返回TRUE所以有数据
SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=3) --->SELECT * FROM B WHERE B.AID=3无值返回TRUE所以没有数据
复制代码


  • 上面 SQL 语句等价于:


SELECT id, name from A WHERE id in (select aid from B)
复制代码

总结

  • 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

发布于: 3 小时前阅读数: 3
用户头像

一位攻城狮的自我修养 2021.04.06 加入

分享技术干货,面试题和攻城狮故事。 你的关注支持是我持续进步的最大动力! https://github.com/ChovaVea

评论

发布
暂无评论
MyBatis中的条件查询!关键字exists用法的详细解析