位置: 编程技术 - 正文

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 测试连接

  • 北京增值税发票勾选认证平台
  • 计提本月附加税会计分录
  • 新公司什么时候开始建账
  • 本年利润怎么结转分录
  • 收入增长率的计算方法
  • 个税返还款要交增值税吗
  • 个人所得税数据已失效,请重新填写
  • 已出库未开票要交税吗
  • 固定资产盘点账务处理
  • 接受劳务是进项还是销项
  • 财务会计制度名称一般是
  • 处置固定资产账务处理例题
  • 收客户款现金折让发票怎么处理
  • 非货币资产交换的会计处理原则
  • 事业单位如何计提工资
  • 微信提现手续费最新规定
  • 处理固定资产一个月卖一点
  • 地产佣金收入属什么收入
  • 个人所得税可以抵扣哪些费用
  • 出口企业增值税优惠政策
  • 进项明细和开票明细不一致怎么办
  • 公司招聘费属于什么科目
  • 成本无发票如何处理
  • 销售收入里面包括免税收入呢
  • 原材料损失计入
  • 贴现扣的钱叫什么
  • 企业分红给企业股东怎么交税
  • 营销策划费用计算公式
  • 印花税的计税依据是销项和进项的金额
  • 银行手续费会开发票吗
  • 分期购车的会计分录
  • 销售收入与销售成本
  • 瓦尔德内尔精彩
  • 卖机械配件平台有哪些
  • 预售商品房转让合同
  • 日本东京秋叶原攻略
  • thinkphp设置伪静态
  • 失控发票成本做账怎么做
  • chat top
  • php curl_init
  • day01-GUI坦克大战01
  • 零申报季报怎么报税的具体流程
  • 织梦设置的关键词看不到
  • 3步搞定纯真ip数量
  • 六税一费和六税两费的区别
  • 民办非注销原因如何写
  • 金税卡报税流程
  • 资产类会计科目记忆口诀
  • 无法偿付的应付账款计入什么科目政府会计
  • 专项附加可以随便填吗
  • 权益法下公允价值变动计入其他综合收益
  • 金税四期上线企业还活吗
  • 国企注册资本实缴
  • 补计提所得税怎么做分录
  • 提的税与实际交的税区别
  • 水利建设行业
  • 收到对方公司退款
  • 车辆保险费会计账务处理
  • 进口货物只有报关单能入账吗
  • 电子钥匙有效期多久
  • window 脚本
  • gentoo安装教程2021
  • windows的设置
  • mac迁移助理是什么意思啊
  • linux系统编译命令
  • quickres.exe - quickres是什么进程 作用是什么
  • 电脑开机后出现win7画面后一直黑屏
  • win8 设置
  • win10无法启动diagnostic policy service
  • unity 3d教程
  • opengl源码在哪里
  • 不使用jsp
  • python中get怎么用
  • js原型使用场景
  • jquery下拉列表框
  • 多线程 python
  • 一般纳税人预缴税款怎么计算
  • 加计抵减怎么计提分录
  • 国税手撕发票图片
  • 宣传中常用的效应包括
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设