位置: 编程技术 - 正文

MySQL的子查询及相关优化学习教程(mysql 子查询)

编辑:rootadmin

推荐整理分享MySQL的子查询及相关优化学习教程(mysql 子查询),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 子查询,mysql子查询写法,mysql子查询写法,mysql 子查询,mysql子查询关键字,mysql子查询效率如何,mysql子查询写法,mysql中的子查询,内容如对您有帮助,希望把文章链接给更多的朋友!

一、子查询1、where型子查询(把内层查询结果当作外层查询的比较条件)

2、from型子查询(把内层的查询结果供外层再次查询)#用子查询查出挂科两门及以上的同学的平均成绩思路:

3、exists型子查询(把外层查询结果拿到内层,看内层的查询是否成立)

二、优化从句式的形式看,子查询分为特殊格式子查询和非特殊格式子查询,特殊格式的子查询中又包括IN、ALL、ANY、SOME、EXISTS等类型的子查询,对于有的类型的子查询,MySQL有的支持优化,有的不支持,具体情况如下。

示例一,MySQL不支持对EXISTS类型的子查询的优化:

EXISTS类型的相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,子查询存在,MySQL没有进一步做子查询的优化工作。

另外的一个EXISTS类型的相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,子查询存在,MySQL没有进一步做子查询的优化工作。

示例二,MySQL不支持对NOT EXISTS类型的子查询的优化:

NOT EXISTS类型的相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,子查询存在,MySQL没有进一步做子查询的优化工作。

另外的一个NOT EXISTS类型的相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,子查询存在,MySQL没有进一步做子查询的优化工作。

示例三,MySQL支持对IN类型的子查询的优化,按也有不支持的情况存在:

IN非相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,表t2被物化后,与表t1执行了半连接(semi join)。尽管有“subquery2”这样的内容看起来是子查询,但是表t2已经被上拉到表t1层执行了半连接,所以MySQL支持IN子查询优化为半连接操作。

另外一个IN非相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,子查询不存在,表t1和t2直接做了块嵌套循环半连接(Block Nested Loop),把子查询上拉到父查询中用嵌套循环半连接完成IN操作。另外,由于子查询上拉,使得增加连接条件“a1=a2”,而原先的条件“a2=”可以利用常量传递优化技术,使得“a1=a2=”,所以查询执行计划中,两个索引扫描的条件分别为:a1 = 、a2 = 。

另外一个IN非相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,子子查询不存在,表t1和t2直接做了块嵌套循环连接(Block Nested Loop),但属于半连接操作(semi join),把子查询上拉到父查询中用嵌套循环半连接完成IN操作。

示例四,MySQL支持对NOT IN类型的子查询的优化

NOT IN非相关子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,表t2做了子查询(SUBQUERY)。而子查询被物化(materialize)。所以,MySQL对于NOT IN子查询采用了物化的优化方式,但不支持子查询的消除。

另外一个NOT IN非相关子查询,查询执行计划如下:

MySQL的子查询及相关优化学习教程(mysql 子查询)

被查询优化器处理后的语句为:

从查询执行计划看,表t2做了子查询(SUBQUERY)。而子查询被物化(materialize)。所以,MySQL对于NOT IN子查询采用了物化的优化方式,但不支持子查询的消除。

示例五,MySQL支持对ALL类型的子查询的优化:

不相关的ALL子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是,子查询被“<= <max>”操作符限制,而子查询中的被查询列a2上存在唯一索引,所以可以利用索引求最值,所以MySQL支持“>ALL”式的子查询优化,子查询只被执行一次即可求得最大值。

不相关的ALL子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是被查询优化器处理后的语句中包含“exists”,这表明MySQL对于“=ALL”式的子查询优化用“EXISTS strategy”方式优化,所以MySQL支持“=ALL”式的子查询优化。

不相关的ALL子查询,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是,子查询被“>= <min>”操作符限制,而子查询中的被查询列a2上存在唯一索引,所以可以利用索引求最值,所以MySQL支持“<ALL”式的子查询优化,子查询只被执行一次即可求得最小值。

示例六,MySQL支持对SOME类型的子查询的优化:

使用了“>SOME”式子的子查询被优化,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是,子查询被“min”函数限制,而子查询中的被查询列a2上存在唯一索引,所以可以利用索引求最值,所以MySQL支持“>SOME”式的子查询优化,子查询只被执行一次即可求得最大值。

使用了“=SOME”式子的子查询被优化,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,没有出现了子查询,表t2被物化,与表t1进行了半连接。

使用了“<SOME”式子的子查询被优化,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是,子查询被“max”函数限制,而子查询中的被查询列a2上存在唯一索引,所以可以利用索引求最值,所以MySQL支持“<SOME”式的子查询优化,子查询只被执行一次即可求得最大值。

示例七,MySQL支持对ANY类型的子查询的优化:

使用了“>ANY”式子的子查询被优化,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是,子查询被“min”函数限制,而子查询中的被查询列a2上存在唯一索引,所以可以利用索引求最值,所以MySQL支持“>ANY”式的子查询优化,子查询只被执行一次即可求得最小值。

使用了“=ANY”式子的子查询被优化,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,没有出现了子查询,表t2被物化,与表t1进行了半连接。

使用了“<ANY”式子的子查询被优化,查询执行计划如下:

被查询优化器处理后的语句为:

从查询执行计划看,出现了子查询(SUBQUERY),但是,子查询被“max”函数限制,而子查询中的被查询列a2上存在唯一索引,所以可以利用索引求最值,所以MySQL支持“<ANY”式的子查询优化,子查询只被执行一次即可求得最大值。

Yii 连接、修改 MySQL 数据库及phpunit 测试连接 database1.修改protected/config/main.php去掉mysql数据库连接方式的注释,并且修改用户名,密码以及连接的数据库。2.新建protected/tests/unit/DbTest.php内容如下:phpc

MySQL中主键索引与聚焦索引之概念的学习教程 主键索引主键索引,简称主键,原文是PRIMARYKEY,由一个或多个列组成,用于唯一性标识数据表中的某一条记录。一个表可以没有主键,但最多只能有一

MySQL中的联合索引学习教程 联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。例如索引是keyin

标签: mysql 子查询

本文链接地址:https://www.jiuchutong.com/biancheng/312351.html 转载请保留说明!

上一篇:MySQL中的事件调度基础学习教程(mysql中事件的作用)

下一篇:Yii 连接、修改 MySQL 数据库及phpunit 测试连接

  • 增值税专用发票使用规定 最新
  • 应交个人所得税计提分录
  • 一般纳税人开劳务专票多少个点
  • 公积金个人缴纳多少
  • 安置残疾人税收优惠
  • 医院收费单能当凭证用吗
  • 电汇凭证的日期为什么必须是当天
  • 什么合同不需要做结算
  • 房地产公司固定资产管理制度
  • 报销差旅费退回现金是什么凭证
  • 汽车行业保险丝
  • 收到保险公司返还的保险费
  • 旅行社开具发票
  • 每股股份价格
  • 资本公积金转增资本属于所有者权益吗
  • 残保金的工资总额是应发还是实发
  • 运费的发票
  • 税务登记证遗失了怎么注销
  • 跨年冲暂估如何做账?
  • 未开发票的结算款怎么入账?
  • 净资产回报率的变化
  • 增值税的征收范围包括在中华人民共和国境内
  • 如何阻止windows10升级到11
  • 鸿蒙3.0平板适配名单
  • 差旅补助需要计提吗
  • 应付账款的暂估入账
  • 抵押房产可以买卖吗
  • 增值税四个税种
  • 发票如何认证及开票
  • 任务栏图标调大了怎么办
  • u盘无法格式化为NTFS
  • 手机cpu性能天梯图排行榜
  • win10右键新建卡死
  • 无法访问或访问被拒绝是怎么解决
  • 出租固定资产取得的收入属于收入要素吗
  • 进项税和销项税谁交
  • 经营特许权
  • EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
  • php读取二进制文件
  • 设备租赁费属于设备费吗
  • vue过滤器可以异步吗
  • javaweb.xml配置文件
  • vue修饰词
  • split 文件分割
  • 教育费附加免税需要计提吗?
  • 装修费摊销费计算公式
  • 网上税则
  • 非营利组织能否开社保账户
  • 工资预提和计提的区别
  • 企业所得税计算器在线计算
  • 出租无形资产取得的收益计入什么科目
  • 交强险必须要买驾乘险才能投保
  • sql server 防止表锁死
  • 哪些合同不用交社保
  • 汽车属于固定资产类吗
  • 建筑图纸设计费多少钱
  • 如何恢复数据库数据
  • mysql 连接语句
  • 无法使用ie浏览器
  • vmware虚拟机步骤
  • win7能不能安装vs2019
  • linux系统基于
  • 部分用户开启隐私,暂时无法查看怎么办
  • linux小技巧
  • 淘宝win10和正版的有什么区别
  • wp8.1升级10
  • cocos2djs教程
  • jquery 限制文件大小
  • 批处理setlocal
  • js下拉列表框
  • shell 比较大小
  • python中re.m
  • 用js实现类的方法
  • javascript教程完整版
  • 孙其功陪你学之——unity3d进程暂停
  • js实现跨域访问的几种方式
  • 北京税务总局
  • 龙华区有几个地方
  • 退车辆购置税流程怎么操作
  • 深圳宝安到揭阳大巴
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设