博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySql 小表驱动大表
阅读量:6274 次
发布时间:2019-06-22

本文共 1141 字,大约阅读时间需要 3 分钟。

在了解之前要先了解对应语法 in 与 exist。

IN:select * from A where A.id in (select B.id from B)

in后的括号的表达式结果要求之输出一列字段。与之前的搜索字段匹配,匹配到相同则返回对应行。

mysql的执行顺序是先执行子查询,然后执行主查询,用子查询的结果按条匹配主查询。

 

EXIST:select * from A where exists(select * from B where B.id= A.id)

exist后的括号里则无输出要求,exist判断后面的结果集中有没有行,有行则返回外层查询对应的行。

ps所以exist还可以这样写: 用常量替换* ,反正是判断有没有行,不需要实际传回的数据。

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

mysql的执行顺序是先执行主查询,将主查询的数据放在子查询中做条件验证。

 

大体看来貌似exist的执行效率比in低,但其实exists子查询在底层做了优化,会忽略select清单,也并不会对每条数据进行对比。

 

 

比如这里有两张表 

+--------+----------+| A.id   | A.name   |       //500行+--------+----------+
+--------+----------+| B.id   | B.name   |    //5000行+--------+----------+

在查询中最好使用小表驱动大表,因为在外层表循环内层的时候,会锁定外层表,如果大表在外,会锁定5k次 。

 

如果要求查询所有id相同的Aname 有两种查询方式

1.select A.name from A where A.id in(select B.id from B)2.select A.name from A where exists(select 1 from B where A.id = B.id)

1.由B表驱动A表 会先执行子查询 大表驱动小表

2.由A表驱动B表 会先执行主查询 小表驱动大表

如果需求变为 查询所有id相同的Bname 

1.select B.name from B where B.id in(select A.id from B)2.select B.name from B where exists(select 1 from A where A.id = B.id)

1.小表驱动大表

2.大表驱动小表

 

转载于:https://www.cnblogs.com/chafanbusi/p/10647471.html

你可能感兴趣的文章
使用Gradle打RPM包
查看>>
“我意识到”的意义
查看>>
淘宝天猫上新辅助工具-新品填表
查看>>
再学 GDI+[43]: 文本输出 - 获取已安装的字体列表
查看>>
nginx反向代理
查看>>
操作系统真实的虚拟内存是什么样的(一)
查看>>
hadoop、hbase、zookeeper集群搭建
查看>>
python中一切皆对象------类的基础(五)
查看>>
modprobe
查看>>
android中用ExpandableListView实现三级扩展列表
查看>>
%Error opening tftp://255.255.255.255/cisconet.cfg
查看>>
java读取excel、txt 文件内容,传到、显示到另一个页面的文本框里面。
查看>>
《从零开始学Swift》学习笔记(Day 51)——扩展构造函数
查看>>
python多线程队列安全
查看>>
[汇编语言学习笔记][第四章第一个程序的编写]
查看>>
android 打开各种文件(setDataAndType)转:
查看>>
补交:最最原始的第一次作业(当时没有选上课,所以不知道)
查看>>
Vue实例初始化的选项配置对象详解
查看>>
PLM产品技术的发展趋势 来源:e-works 作者:清软英泰 党伟升 罗先海 耿坤瑛
查看>>
vue part3.3 小案例ajax (axios) 及页面异步显示
查看>>