mysql中exists和in的区别
来源:互联网 发布:php字符串的拆分 编辑:程序博客网 时间:2024/05/21 21:33
exists ()后面的子查询被称作相关子查询 他是不返回列表的值,只返回一个boolean型的值。
其运行方式是先运行朱查询一次,再去子查询里查询与其对应的结果 如果是true 则输出,反之则不输出,在根据主查询中的每一行去子查询里去查询。
in()后面的子查询是返回的结果集,执行次序和exists()不一样,子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表,符合要求的输出,反之不输出。
exists() 对外表用loap 逐条查询,每条查询都会查看exists的条件语句,当exists里的条件语句能够返回记录行时,条件就为真,返回当前loop到的这条记录。反之如果exists里的条件语句不能返回记录行,怎当前loop到的这条记录被丢弃,exists的条件就像一个bool条件,当能返回结果集则为TRUE,不能安徽结果集则返回false。
例如:
select * from B where cc in (select cc from A) 效率高,用到了B表上cc列的索引;
select * from B where exists(select cc from A where cc=B.cc) 效率低,用到了A表上cc列的索引。
not in 和not exists如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;而not extsts 的子查询依然能用到表上的索引。所以无论那个表大,用not exists都比not in要快。
in 与 =的区别
select name from student where name in ('zhang','wang','li','zhao');
与
select name from student where name='zhang' or name='li' or name='wang' or name='zhao'
的结果是相同的。
1 0
- Mysql中exists和in的区别
- MySQL中exists和in的区别
- mysql中exists和in的区别
- MySQL查询条件中exists和in的区别
- SQL中exists和in的区别
- SQL中exists和in的区别
- SQL中exists和in的区别
- oracle中in和exists的区别
- SQL中exists和in的区别
- oracle中in和exists的区别
- Oracle中in和exists的区别
- oracle中in和exists的区别
- SQL中exists和in的区别
- SQL中in和exists的区别
- oracle中in和exists的区别
- exists,in的区别-mysql
- MySQL中exists和join的区别
- SQL中IN和EXISTS用法的区别,sql中exists,not exists的用法
- 书籍:PHP与MYSQL程序设计:高级OPP特性(第七章):持续更新(完)
- LeetCode 203 Remove Linked List Elements(链表操作)
- 14-进程间通信-消息队列(功能:传输数据)
- activemq-集群和主从模式 学习笔记
- 欢迎使用CSDN-markdown编辑器
- mysql中exists和in的区别
- android的界面定制
- jvisualvm使用注意事项
- js实验2.(4)AJAX的POST请求
- 数据结构与算法学习笔记第二天--什么是算法
- grub rescue模式下启动
- Android之什么时候调用onSaveInstance方法的时候(为什么按Home键盘会调用,按Back不调用)
- Android NDK 在Release模式下编译提示找不到方法的问题
- 学习编程的过程中可能会走哪些弯路,有哪些经验可以参考?