MyBatis框架中的条件查询exists的用法的详细解析
MyBatis框架中的exists用法
exists用法
【MyBatis框架中的条件查询exists的用法的详细解析】使用示例
总结
文章图片
exists用法
exists:如果括号内子查询语句返回结果不为空,说明where条件成立,就会执行主SQL语句如果括号内子查询语句返回结果为空,说明where条件不成立,就不会执行主SQL语句
notexists:与exists相反如果括号内子查询语句结果为空,说明表示where条件成立,就会执行主SQL语句如果括号内子查询语句结果不为空,说明表示where条件不成立,就不会执行主SQL语句exists与in的区别:in只能返回一个字段值exists强调是否返回结果集,不要求知道返回什么,exists允许返回多个字段exists的效率一般优于in:使用exists,Oracle首先会检查主查询,然后运行子查询直到找到第一个匹配项使用in子查询时,首先会执行子查询,并将获得的结果列表放在一个加了索引的临时表中exists的效率优于distinct:当提交一对多表信息查询时,就可以避免在select中使用distinct因为RDBMS核心模块将在子查询的条件一旦满足后,立即返回结果,所以自带去重.以下两组SQL语句等价:SELECTdistinctdept_no,dept_namefromdeptD,EMPEWHERED.dept_no=E.dept_no;SELECTdept_no,dept_namefromdeptDWHEREEXISTS(SELECT1fromempEWHEREE.dept_no=D.dept_no);exists适合外表的结果集小的情况in适合内外表都很大的情况
文章图片
使用示例
exists:
SELECTID,NAMEFROMAWHERE
EXISTS(SELECT*FROMBWHEREA.ID=B.AID)
SQL语句分解:
SELECTID,NAMEFROMAWHEREEXISTS(SELECT*FROMBWHEREB.AID=1)
--->SELECT*FROMBWHEREB.AID=1有值返回TRUE所以有数据
SELECTID,NAMEFROMAWHEREEXISTS(SELECT*FROMBWHEREB.AID=2)
--->SELECT*FROMBWHEREB.AID=2有值返回TRUE所以有数据
SELECTID,NAMEFROMAWHEREEXISTS(SELECT*FROMBWHEREB.AID=3)
--->SELECT*FROMBWHEREB.AID=3无值返回TRUE所以没有数据
上面SQL语句等价于:
SELECTid,namefromAWHEREidin(selectaidfromB)
总结
SQL中in,notin,exists,notexists的区别:in:确定给定的值是否与子查询或者列表中的值匹配in关键字选择与列表中任意一个值匹配的行in关键字之后的项目必须用逗号隔开,并且括在括号中notin:通过notin关键字引入的子查询也返回一列零值或更多值exists:指定一个子查询,检测行的存在相当于两个集合的交集exists后面可以是整句的查询语句,in后面只能是单列查询语句notexists:相当于两个集合的差集exists和notexists返回的结果类型是Boolean:如果子查询包含行:exists返回TRUEnotexists返回FALSE
文章图片
- mybatis|2.2亿花粉升级后,鸿蒙系统暴露出新问题,华为至今没有回应
- “大筛”中的别样“红”:志愿者暖心陪你度寒冬
- 噪音|聊聊社交产品中的信号与暗示
- CPU|mybatis返回数据列表同时返回数据总数
- 一体机|触摸屏是以何种方式应用在电气室机柜中的?
- Windows|看不懂电脑中的英文进程,不敢轻易关闭?教你简单避开重要进程
- 康德莱|康德莱医械(01501)与康德莱订立2022年医疗标准件及模具销售框架协议
- 一加科技|一加10Pro在散热上铆足了劲,散热硅胶以及金属框架,能给的都给了
- 实在智能RPA机器人在财务工作中的具体应用
- mybatis|支付“国家队”诞生!用户已超1.4亿,微信和支付宝的垄断被打破