Mysql之IN 和 Exists 用法
1.基本用法

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

Exists:后面的子查询被称做相关子查询, 他是不返回列表的值的.只是返回一个ture或false的结果(这也是为什么子查询里是 "select 1 "的原因,当然也可以select任何东西) 其运行方式是先运行主查询一次。再去子查询里查询与其对应的结果,如果是ture则输出,反之则不输出.再根据主查询中的每一行去子查询里去查询。

2.运行过程

Exists执行顺序如下:
  1.首先执行一次外部查询
  2.对于外部查询中的每一行分别执行一次子查询,而且每次执行子查询时都会引用外部查询中当前行的值。
  3.使用子查询的结果来确定外部查询的结果集。(如果外部查询返回100行,SQL 就将执行101次查询,一次执行外部查询,然后为外部查询返回的每一行执行一次子查询。但实际上,SQL的查询 优化器有可能会找到一种更好的方法来执行相关子查询,而不需要实际执行101次查询。)

IN的执行过程如下:

1.首先运行子查询,获取子结果集

2.主查询再去结果集里去找符合要求的字段列表,.符合要求的输出,反之则不输出。

3.区别

3.1 IN和Exists
IN是把外表和内表作hash 连接,而Exists是对外表作loop循环,每次loop循环再对内表进行查询。一直以来认为Exists比IN效率高的说法是不准确的。
如果查询的两个表大小相当,那么用IN和Exists差别不大。如果两个表中一个较小,一个是大表,则子查询表大的用Exists,子查询表小的用IN:
例如:表A(小表),表B(大表):
  select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;
  select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的:
  select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;
  select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
3.2 not IN 和not Exists
  not IN 和not Exists如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;而not extsts 的子查询依然能用到表上的索引。所以无论那个表大,用not Exists都比not IN要快。
3.3 in 与 = 的区别
  select name from student where name in (‘A’,‘S’,‘D’,‘F’);

  select name from student where name=‘A’ or name=‘S’ or name=‘D’ or name=‘F’
的结果是相同的。

Mysql之IN 和 Exists 用法相关推荐

  1. mysql check column exists_Mysql exists用法小记

    简介 EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False. EXISTS 指定一个子查询,检测行的存在.语法:EXISTS subquer ...

  2. mysql is exists_Mysql exists用法小结

    简介 EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False. EXISTS 指定一个子查询,检测行的存在.语法:EXISTS subquer ...

  3. mysql exists怎么用_Mysql exists用法小结

    简介 EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False. EXISTS 指定一个子查询,检测行的存在.语法:EXISTS subquer ...

  4. MySQL中sum和count用法总结

    MySQL中sum和count用法总结 1.sum 2.count 例子:要求:查询出2门及2门以上不及格者的平均成绩. 3.MySQL 分组之后如何统计记录条数 gourp by 之后的 count ...

  5. oracle中的exists 和 not exists 用法详解

    from:http://blog.sina.com.cn/s/blog_601d1ce30100cyrb.html oracle中的exists 和 not exists 用法详解 (2009-05- ...

  6. oracle中的exists 和not exists 用法详解

    有两个简单例子,以说明 "exists"和"in"的效率问题 1) select * from T1 where exists(select 1 from T2 ...

  7. MYSQL数值运算符和函数用法

    mysql也有数值运算,那么列出常见的函数 ceil() div() floor() mod() power() round() truncate()等等,具体说说MYSQL数值运算符和函数用法. 1 ...

  8. mysql 实时聚合分析,mysql累积聚合原理与用法实例分析

    本文实例讲述了mysql累积聚合原理与用法.分享给大家供大家参考,具体如下: 累积聚合为聚合从序列内第一个元素到当前元素的数据,如为每个员工返回每月开始到现在累积的订单数量和平均订单数量 行号问题有两 ...

  9. mysql 普通索引使用方法,Mysql索引类型与基本用法实例分析

    本文实例讲述了Mysql索引类型与基本用法.分享给大家供大家参考,具体如下: 索引 MySQL目前主要有以下几种索引类型: 普通索引 唯一索引 主键索引 组合索引 全文索引 - 普通索引 是最基本的索 ...

最新文章

  1. Python 单例模式
  2. 第三章 函数编程
  3. 互联网1分钟 |1217
  4. 2.3.7 操作系统之管程和java中实现管程的机制
  5. swift 设计模式之-责任链模式
  6. vmware ubuntu重置root密码
  7. LWIP的TCP相关API
  8. 软件工程概论--课后作业1
  9. 运行phpize时出现:Cannot find autoconf
  10. 8月7日晚八点分享-推荐系统面试/概览
  11. 了解有关计算机病毒的知识,从基础知识开始 全面认识计算机病毒
  12. hp刀片服务器性能分析,IBM刀片服务器与高性能计算-20210723075634.ppt-原创力文档...
  13. 兰大《银行会计学》命题作业离线作业
  14. kaminari分页插件样式
  15. javascript判断文本语言类型
  16. PaddlePaddle第二周学习笔记
  17. 两代 Windows 性能大比拼!Win8 完胜 Win7
  18. 使用filter()方法进行数据过滤
  19. RabbitMQ系列3之运行和Rabbit服务
  20. 5、创建用户微服模块,使用路由网关(gateway 3.0.3)微服进行访问

热门文章

  1. vue 图表 组件库 vue-highcharts
  2. scikit-learn与mllib
  3. html提交按钮标签代码是什么,怎么使用?(示例)
  4. 杭州市人社局携手法大大,加速推广电子劳动合同
  5. centos7 centos-home 磁盘空间转移至centos-root下
  6. “重新定义吹风机器”,物种起源获数百万元天使融资
  7. 乐华阅卷系统打不开服务器,乐华网上阅卷系统1.0操作手册.doc
  8. 实现企业的降本增效,设备管理应该怎么做?
  9. img加载本地图片_图片加载技术-懒加载和预加载
  10. 2020年生肖码表图_2020年会发大财的生肖(图)