当前位置:  数据库>sqlserver

SQL查询中in和exists的区别分析

    来源: 互联网  发布时间:2014-10-12

    本文导语:  select * from A where id in (select id from B); select * from A where exists (select 1 from B where A.id=B.id); 对于以上两种情况,in是在内存里遍历比较,而exists需要查询数据库,所以当B表数据量较大时,exists效率优于in。 1、select * from A where id in (sel...

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

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

对于以上两种情况,in是在内存里遍历比较,而exists需要查询数据库,所以当B表数据量较大时,exists效率优于in。

1、select * from A where id in (select id from B);

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


    
 
 

您可能感兴趣的文章:

  • SQL查询分析工具 SQL Workbench/J
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • 基于SQL的日志分析工具 myselect
  • 关于SQL嵌套的误解分析
  • sql server中通过查询分析器实现数据库的备份与恢复方法分享
  • SQL语句中SUM与COUNT的区别深入分析
  • SQL Server 死锁原因分析与解决办法
  • 有关sql server中千万级数据的like问题分析
  • unix shell 里调用sql ,请帮手分析问题,谢谢
  • sql server 2008时间查询问题分析
  • 通过分析SQL语句的执行计划优化SQL
  • SQL 中having 和where的区别分析
  • jdbc连接sql server数据库问题分析
  • 深入sql数据连接时的一些问题分析
  • SQL查询前10条记录(SqlServer/mysql/oracle)的语法分析
  • Discuz7.2版的faq.php SQL注入漏洞分析
  • 对于ThinkPHP框架早期版本的一个SQL注入漏洞详细分析
  • SQL Server 置疑、可疑、正在恢复等情况分析
  • SQL 查询分析中使用net命令问题
  • SQL Server和Oracle并行处理比较分析
  • if exists和if not exists关键字用法(sql server)
  • sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
  • sql server中Exists的用法举例
  • sql server中exists与in、not exists与not in
  • sql not in 与not exists使用中的细微差别
  • sql语句中exists用法举例
  • SQL SERVER中关于exists 和 in的简单分析
  • SQL中exists的使用方法
  • sql语句中in与exists的区别
  • SQL优化之针对count、表的连接顺序、条件顺序、in及exist的优化
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql的SQL_NO_CACHE(在查询时不使用缓存)和sql_cache用法
  • sql中count或sum为条件的查询示例(sql查询count)
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • mysqli多查询特性 实现多条sql语句查询
  • sql server简单查询的例子(sql入门)
  • 根据时间范围条件查询数据sql语句
  • 在SQL Server中使用SQL语句查询一个存储过程被其它所有的存储过程引用的存储过程名
  • shell中关于sql查询结果的判断?
  • SQL查询工具 SuperQuaiL
  • HBase上使用SQL查询 Phoniex
  • sql 查询所有数据库、表名、表字段的代码
  • 查询SQL Server中所有数据库的数据文件位置的sql脚本
  • 在SQL Server中查询资料库的TABLE数量与名称的sql语句
  • 在线等待!一个简单的SQL查询问题?
  • SQL SERVER 查询正在实行的SQL语句
  • SQLServer中用T—SQL命令查询一个数据库中有哪些表的sql语句
  • SQL查询问题
  • SQL日期查询与比较方法
  • SQL Server日志过大会影响查询结果
  • 将string数组转化为sql的in条件用sql查询
  • 在jsp中如何写sql查询?
  • java命名空间java.sql接口statement的类成员方法: executeupdate定义及介绍
  • 请问,这是什么错误!java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][Named Pipes]??????? SQL Server?虽然分少,但一定给,只要您是前5名回复者中最好的以为!
  • java命名空间java.sql接口connection的类成员方法: nativesql定义及介绍
  • SQL Server统计SQL语句执行时间的脚本
  • java命名空间java.sql接口preparedstatement的类成员方法: executeupdate定义及介绍
  • SQL客户端软件 PKLite SQL Client
  • java命名空间java.sql接口rowid的类成员方法: getbytes定义及介绍
  • SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)
  • java命名空间java.sql接口ref的类成员方法: getbasetypename定义及介绍
  • SQL客户端管理工具 SQuirreL SQL Client




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3