SQL关于IN和EXISTS的用法和区别的比较
来源:互联网 发布:java中缺省是什么意思 编辑:程序博客网 时间:2024/05/15 11:10
1.exist,not exist一般都是与子查询一起使用. In可以与子查询一起使用,也可以直接in (a,b.....)。
2.exist会针对子查询的表使用索引. not exist会对主子查询都会使用索引. in与子查询一起使用的时候,只能针对主查询使用索引. not in则不会使用任何索引. 注意,一直以来认为exists比in效率高的说法是不准确的。
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。
IN 其实与等于相似,比如in(1,2) 就是 = 1 or = 2的一种简单写法,所以一般在元素少的时候使用IN,如果多的话就用exists
exists的用法跟in不一样,一般都需要和子表进行关联,而且关联时,需要用索引,这样就可以加快速度。
2.exist会针对子查询的表使用索引. not exist会对主子查询都会使用索引. in与子查询一起使用的时候,只能针对主查询使用索引. not in则不会使用任何索引. 注意,一直以来认为exists比in效率高的说法是不准确的。
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。
IN 其实与等于相似,比如in(1,2) 就是 = 1 or = 2的一种简单写法,所以一般在元素少的时候使用IN,如果多的话就用exists
exists的用法跟in不一样,一般都需要和子表进行关联,而且关联时,需要用索引,这样就可以加快速度。
IN
确定给定的值是否与子查询或列表中的值相匹配。
EXISTS
指定一个子查询,检测行的存在。
比较使用 EXISTS 和 IN 的查询
exists()后面的子查询被称做相关子查询 他是不返回列表的值的.只是返回一个ture或false的结果,其运行方式是先运行主查询一次 再去子查询里查询与其对应的结果 如果是ture则输出,反之则不输出.再根据主查询中的每一行去子查询里去查询.
in()后面的子查询 是返回结果集的,换句话说执行次序和exists()不一样.子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表去.符合要求的输出,反之则不输出.
0 0
- SQL关于IN和EXISTS的用法和区别的比较
- SQL in和exists的用法区别
- SQL中IN和EXISTS用法的区别,sql中exists,not exists的用法
- SQL中IN和EXISTS用法的区别,sql中exists,not exists的用法
- sql中in 和 exists的用法和性能区别
- sql 中 in 和 exists 的 用法和区别
- sql优化(一)--关于exists和in的比较
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- SQL中IN和EXISTS用法的区别
- 成为GEEK是个梦想,从这一刻出发。
- 3.GitHub译文之创建仓库分支
- presenting controller & presented controller 如何区分
- Android Api Demos登顶之路(五十三)Service Foreground Service Controller
- c#格式化数字
- SQL关于IN和EXISTS的用法和区别的比较
- 设计模式在游戏中的应用--观察者模式(十)
- hdoj 2883 kebab 【时间区间离散化 + 最大流】
- c++多态原理
- 内存泄露原因分析
- UINavigationController(loading...)
- java集合
- [leetcode] 125.Valid Palindrome
- 用ping查看计算机的关于网卡,是否接入路由,是否接入Internet