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 语句等价:
使用示例
exists:
SQL 语句分解:
上面 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
版权声明: 本文为 InfoQ 作者【攻城狮Chova】的原创文章。
原文链接:【http://xie.infoq.cn/article/2753b172957ad0113c540dc60】。文章转载请联系作者。
评论