当前位置:首页 > 技术 >

exists用法总结动画(exist函数的使用方法)

来源:原点资讯(www.yd166.com)时间:2023-11-02 07:05:48作者:YD166手机阅读>>

MyBatis框架中的exists用法
  • EXISTS用法
  • 使用示例
  • 总结

exists用法总结动画,exist函数的使用方法(1)

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用法总结动画,exist函数的使用方法(2)

使用示例
  • 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返回TRUEnot exists返回FALSE

exists用法总结动画,exist函数的使用方法(3)

栏目热文

exists的用法(exist用法和注意事项)

exists的用法(exist用法和注意事项)

概述一般在做SQL优化的时候讲究使用exists带替代IN的做法,理由是EXISTS执行效率要比IN高。个人理解:IN表...

2023-11-02 06:52:45查看全文 >>

exists函数怎么用(exists查询的语句格式)

exists函数怎么用(exists查询的语句格式)

概述抽空总结一下mysql的一些概念性内容,涉及存储过程、函数、视图、触发器等。一、查看存储过程、函数、视图、触发器、表...

2023-11-02 07:23:53查看全文 >>

exists关键字的用法(exists方法的作用是)

exists关键字的用法(exists方法的作用是)

EXISTS语法:SELECT 字段 FROM table WHERE EXISTS (subquery); 参数:su...

2023-11-02 07:33:41查看全文 >>

exists中文是什么(exists汉语是什么)

exists中文是什么(exists汉语是什么)

高中一年级英语必修2单词Unit5classical/'klæsɪkl/adj.古典的;经典的。classic(...

2023-11-02 07:24:00查看全文 >>

sql语句中的exists用法(sql中exists与in区别)

sql语句中的exists用法(sql中exists与in区别)

1、简介• 不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询• 相关子查询:子查询的查询条件依赖于外层父查...

2023-11-02 07:10:48查看全文 >>

mysqlexists用法(mysql8 exists怎么用)

mysqlexists用法(mysql8 exists怎么用)

先举个例子SELECT c.Custromerid,CompanyName FROM Customers c where...

2023-11-02 06:59:48查看全文 >>

花呗还款日在哪里调整(花呗还款日怎么调一个月)

花呗还款日在哪里调整(花呗还款日怎么调一个月)

新京报讯(记者 陈鹏)“支付宝调整花呗还款日”的消息今日(7月30日)在社交媒体上引起网友热议。支付宝页面显示,目前针对...

2023-11-02 07:17:27查看全文 >>

花呗去哪里设置还款日(花呗调整还款日怎么调整的)

花呗去哪里设置还款日(花呗调整还款日怎么调整的)

支付宝花呗还款日开启预约调整 每月可选15日20日还款新华社杭州7月30日电(记者张璇)记者30日从支付宝获悉,支付宝对...

2023-11-02 06:59:11查看全文 >>

花呗还款日调整怎么操作(花呗还款日怎么设置成功的)

花呗还款日调整怎么操作(花呗还款日怎么设置成功的)

【支付宝新功能?手把手教你调整花呗还款日】支付宝近日发布了一项新功能,如果你的支付宝花呗已经开通满一年以上,那么就可以在...

2023-11-02 07:16:11查看全文 >>

花呗还款日在哪里可以调整(花呗还款日调整到什么时间合适)

花呗还款日在哪里可以调整(花呗还款日调整到什么时间合适)

支付宝推出“今年花明年还”活动,为花呗受邀用户提供特殊待遇。内测期用户可以在10月13日至14日报名参与,正式期用户则在...

2023-11-02 07:15:08查看全文 >>

文档排行