MyBatis中exists用法

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:
      • 相当于两个集合的差集
    • existsnot exists返回的结果类型是Boolean:
      • 如果子查询包含行:
        • exists返回TRUE
        • not exists返回FALSE











萌新小号主在线求关注同名公众号!分享技术干货,面试题和攻城狮故事。
您的关注支持是我持续进步的最大动力!一起学习,共同进步。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

攻城狮Chova

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值