转载自:http://blog.csdn.net/lick4050312/article/details/4476333

select * from A
where id in(select id from B)

以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B表中的id相等,如果相等则将A表的记录加入结果集中,直到遍历完A表的所有记录.
它的查询过程类似于以下过程

List resultSet=[];
Array A=(select * from A);
Array B=(select id from B);

for(int i=0;i<A.length;i++) {
   for(int j=0;j<B.length;j++) {
      if(A[i].id==B[j].id) {
         resultSet.add(A[i]);
         break;
      }
   }
}
return resultSet;

可以看出,当B表数据较大时不适合使用in(),因为它会B表数据全部遍历一次.
如:A表有10000条记录,B表有1000000条记录,那么最多有可能遍历10000*1000000次,效率很差.
再如:A表有10000条记录,B表有100条记录,那么最多有可能遍历10000*100次,遍历次数大大减少,效率大大提升.

结论:in()适合B表比A表数据小的情况

select a.* from A a
where exists(select 1 from B b where a.id=b.id)

以上查询使用了exists语句,exists()会执行A.length次,它并不缓存exists()结果集,因为exists()结果集的内容并不重要,重要的是结果集中是否有记录,如果有则返回true,没有则返回false.
它的查询过程类似于以下过程

List resultSet=[];
Array A=(select * from A)

for(int i=0;i<A.length;i++) {
   if(exists(A[i].id) {    //执行select 1 from B b where b.id=a.id是否有记录返回
       resultSet.add(A[i]);
   }
}
return resultSet;

当B表比A表数据大时适合使用exists(),因为它没有那么遍历操作,只需要再执行一次查询就行.
如:A表有10000条记录,B表有1000000条记录,那么exists()会执行10000次去判断A表中的id是否与B表中的id相等.
如:A表有10000条记录,B表有100000000条记录,那么exists()还是执行10000次,因为它只执行A.length次,可见B表数据越多,越适合exists()发挥效果.
再如:A表有10000条记录,B表有100条记录,那么exists()还是执行10000次,还不如使用in()遍历10000*100次,因为in()是在内存里遍历比较,而exists()需要查询数据库,我们都知道查询数据库所消耗的性能更高,而内存比较很快.

结论:exists()适合B表比A表数据大的情况

当A表数据与B表数据一样大时,in与exists效率差不多,可任选一个使用.

程序猿必读

最新文章

  1. Pivot 和 Unpivot
  2. LeetCode之387. First Unique Character in a String
  3. Nancy 学习-进阶部分 继续跨平台
  4. C# EventHandler and Delegate(委托的使用)
  5. React直出实现与原理
  6. 【转】 Linux下目录结构
  7. js练习【DOM操作】
  8. Boost源代码学习---shared_ptr.hpp
  9. .net mvc页面UI之Jquery博客日历控件
  10. msyql sql语句
  11. bzoj3289
  12. C#内置函数 RunSql的使用
  13. Visual Studio 2017 Enterprise (15.3)
  14. 计算机基础,Python基础--变量以及简单的循环
  15. 628. Maximum Product of Three Numbers
  16. maven项目管理
  17. MySql恢复密码的过程
  18. #Leetcode# 633. Sum of Square Numbers
  19. python+unittest+requests+HTMLRunner编写接口自动化测试集
  20. PTA——32位前导零

热门文章

  1. 使用centos 5.x 64位系统安装astgo 2014 v7.3教程(含全套安装文件)
  2. 数据库部署到linux服务器,供本地访问。
  3. Java高质量20问
  4. Set-----集合入门
  5. 灾备还原之gitlab
  6. 非常无聊——STD::sort VS 基数排序
  7. myeclipse配置tomcat后,无法正常使用的问题
  8. Microsoft SQL Server 2008/2012 Internals 一处疑问
  9. Android仿今日头条和知乎等App顶部滑动导航实现代码分析及源码下载
  10. jQuery——this