假设如下应用:
两张表——用户表TDefUser(userid,address,phone)和消费表 TAccConsume(userid,time,amount),需要查消费超过5000的用户记录。
用exists:
select * from TDefUser
where exists (select 1 from TAccConsume where TDefUser.userid=TAccConsume.userid and TAccConsume.amount>5000)
用in:
select * from TDefUser
where userid in (select userid from TAccConsume where TAccConsume.amount>5000)

通常情况下采用exists要比in效率高。

exists()后面的子查询被称做相关子查询 他是不返回列表的值的.只是返回一个ture或false的结果(这也是为什么子查询里是"select 1"的原因,换成"select 6"完全一样,当然也可以select字段,但是明显效率低些)
其运行方式是先运行主查询一次 再去子查询里查询与其对应的结果 如果是ture则输出,反之则不输出.再根据主查询中的每一行去子查询里去查询.

in()后面的子查询 是返回结果集的,换句话说执行次序和exists()不一样.子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表去.符合要求的输出,反之则不输出.

比如用户表TDefUser(userid,address,phone),消费表 TAccConsume(userid,time,amount)数据如下:

消费表聚集索引是userid,time
数据(注意因为有聚集索引,实际存储也是按以下次序的)
1   2006-1-1  200
1   2006-1-2  300
1   2006-1-2  500
1   2006-1-3  2000
1   2006-1-3  2000
1   2006-1-4  400
1   2006-1-5  500
2   2006-1-1  200
2   2006-1-2  300
2   2006-1-2  500
2   2006-1-3  2000
2   2006-1-3  6000
2   2006-1-4  400
2   2006-1-5  8000
3   2006-1-1  7000
3   2006-1-2  30000
3   2006-1-2  50000
3   2006-1-3  20000

语句:
select * from TDefUser
where exists (select 1 from TAccConsume where TDefUser.userid=TAccConsume.userid and TAccConsume.amount>5000)

对于userid=1,需要找所有记录,才返回false,与第二个语句的效率差不多
对于userid=2,找到2006-1-3的记录,就返回true,比第而个语句的效率高
对于userid=3,第一条记录就返回true,比第二个语句的效率高

语句
select * from TDefUser
where userid in (select userid from TAccConsume where TAccConsume.amount>5000)

返回空记录集
2
2
3
3
3
3

再判断

语句
select * from TDefUser
where userid in (select userid from TAccConsume where userid=TDefUser.userid and amount>5000)

对于userid=1,需要找所有记录,返回空记录集,比较判断
对于userid=2,需要找所有记录,返回记录集
2
2
,比较判断
对于userid=3需要找所有记录,返回记录集
3
3
3
3
,比较判断

表中如果没有聚集索引,对exists每个userid查找的条数都不同,但都是<=第三个语句需要扫描的条数,极端的(比如> 5000的都是在最后)与第三个语句效率相似,一般的比第二个语句快,所以说,“一般”exists比in效率高

转载于:https://www.cnblogs.com/lich/archive/2012/02/08/2342935.html

SQL中exists和in的区别相关推荐

  1. sql中exists替换in的区别

    在sql中使用exists替换in查询时要注意使用exists时一定要关联主查询和子查询的关联不然查询会得不到相应的结果如下语句:  语句一使用in查询:  select realname from ...

  2. sql中exits和in的区别

    sql中exits和in的区别 转:http://hi.baidu.com/delphi_relive/blog/item/d7c0034a49c4932208f7ef21.html in 和 exi ...

  3. SQL中where与having的区别

    SQL中where与having的区别 目录 SQL中where与having的区别 创建表 插入数据 进行聚合操作 # WHERE是在聚合之前进行数据行的过滤而HAVING实在聚合之后进行新数据的过 ...

  4. SQL中modify和alter用法区别

    SQL中modify和alter用法区别 1. 所属能力大小不同: modify:只能用于修改字段的属性 例如:把age字段变为非空(针对persons表中的age这一个字段进行修改) ALTER T ...

  5. SQL中EXISTS理解使用

    SQL中EXISTS的理解使用 关联子查询 EXISTS理解使用 关联子查询 在讲述EXISTS用法之前,先讲述一下关联子查询: 关联子查询:是指在内查询中需要借助于外查询,而外查询离不开内查询的执行 ...

  6. 数据库查询语句SQL中like、%、-的区别

    数据库查询语句SQL中like.%.-的区别 数据库查询语句SQL中like.%.-的区别 %百分号通配符:表示任何字符出现任意次数(可以是0次) SQL 语句选取 name 以字母 "k& ...

  7. sql中=null和is null区别

    sql中=null和is null区别 前言 关于sql语句对null的处理尤其小心,这个null处理的知识点我看了好几次,但是很容易再次犯错,这次记录一个点, 因为这个错误是我看一个帖子看到的错误的 ...

  8. SQL中exists关键字的用法

    exists用于检查一个子查询是否至少会返回一行数据(即检测行的存在),返回值为true或false.         语法: exists subquery         参数: subquery ...

  9. 《小常识-23》sql中any与some的区别

    #在 SQL 中 ANY 和 SOME 是同义词,所以下面介绍的时候只使用 ANY,SOME 的用法 #和功能和 ANY 一模一样.和 IN 运算符不同,ANY 必须和其他的比较运算符共同使用,而 # ...

最新文章

  1. Python html 代码转成图片、PDF
  2. PyCharm 安装插件
  3. SuperMap IS.NET自定义Action添加Mark
  4. MSSQLSERVER查询分析器连接的方法
  5. Git - 操作指南
  6. Linux防火墙iptables配置详解
  7. Live2D 博客页面添加板娘
  8. 人民币对澳元汇率的大数据分析与预测
  9. 用TreeWalk提高网速及其在vista中的安装方法
  10. 【实地测试】新疆塔克拉玛干沙漠进行实地通信测试
  11. 王者荣耀无限火力服务器,王者荣耀无限火力8.0
  12. HTML5字体设置重影,Word怎么设置字体重影
  13. 前端面试题之【CSS】
  14. ETL-kettle/pentaho的二次开发
  15. 计算机专业大学排名评估,2020全国计算机专业大学排名
  16. Java简单雷电游戏代码
  17. 西电职称计算机报名,西安电子科技大学.PDF
  18. jmeter脚本之AES解密
  19. 自动处理【支付宝交易支付投诉管理系统】配置指南
  20. orecal 中的trim

热门文章

  1. 实现点击打卡_打卡APP哪家强?快来看!这里有一款超好用的轻量级免费的习惯养成APP!...
  2. excel打印预览在哪里_别再浪费A4纸了,Excel按下这个键,一张纸可以打印全部表格内容...
  3. 教你解决ssh连接慢的问题
  4. elasticsearch 文档_ElasticSearch系列04:索引与文档的CURD
  5. Linux之文件系统介绍
  6. 测试面试题集-3.生活物品测试:行李箱、电梯、洗衣机
  7. 韩国财长:韩国将按计划推进加密货币征税
  8. ChaiNext:大盘调整,主流币种还未稳住阻力位
  9. 灰度MANA信托增持729.04万MANA,FIL持仓增长185%
  10. SAP License:SAP系统License查看申请及导入