详细分析MyBatis框架中exists的基本使用
【摘要】 本篇文章中主要介绍了MyBatis框架中exists的基本用法。在介绍exists的用法的同时,也介绍了not exists的基本使用,说明了exists和in在使用过程中的区别。使用一个具体示例对MyBatis框架中使用exists进行具体详细的说明。最后对SQL中的in,not in,exists,not 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与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
- 如果子查询包含行:
- in:
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)