zoukankan      html  css  js  c++  java
  • 数据库中IN和EXISTS的区别

    一个是问in exist的区别,一个是not in和not exists的区别

    把这两个很普遍性的网友比较关心的问题总结回答一下。

    in和exist的区别

    从sql编程角度来说,in直观,exists不直观多一个select,
    in可以用于各种子查询,而exists好像只用于关联子查询

    从性能上来看
    exists是用loop的方式,循环的次数影响大,外表要记录数少,内表就无所谓了

    in用的是hash join,所以内表如果小,整个查询的范围都会很小,如果内表很大,外表如果也很大就很慢了,这时候exists才真正的会快过in的方式。

    not in和not exists的区别

    not in内外表都进行全表扫描,没有用到索引;
    not extsts 的子查询能用到表上的索引。

    所以推荐用not exists代替not in

    不过如果是exists和in就要具体看情况了

    有时间用具体的实例和执行计划来说明。

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/inthirties/archive/2009/08/26/4485630.aspx

    总结:

    总结:
    1、 in可能被优化为 连接
    2in 在未被优化时,外表小,内表大时(要建临时表并排序 耗时) 效率低
    3、 exists 外表数据量大,速度肯定慢,,即使是in同样一样,而对于内表数据量多少跟索引有关。
    4in 和 exists 在外表返回的数据量很大时也是低效的。
     
    因此,,外表(驱动表) 应该都尽可能的小。
     
    
    5、 not in 不走索引的,因此不能用
    6、 not exists走索引的。


     

  • 相关阅读:
    从Android源码修改cpu信息
    lintcode-->翻转字符串
    lintcode-->哈希函数
    PCP架构设计
    PCP项目立项
    linux下wc功能的简单实现
    goahead3.6.3就基本使用(后台上传信息到html页面),高手请忽略
    四则运算生成器
    快速看完软件工程教材后,我的疑惑
    软件工程学习
  • 原文地址:https://www.cnblogs.com/yangzhilong/p/2998191.html
Copyright © 2011-2022 走看看