位置: 编程技术 - 正文

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

  • 增值税开票软件怎么改开票人
  • 委托加工应税消费品收回后直接销售
  • 滴滴电子普通发票怎么抵扣
  • 微信收款和支付宝收款有啥区别
  • 蔬菜专用发票在哪里开
  • 衍生工具和非衍生工具怎么区分
  • 商品卖亏的会计分录
  • 以前年度损益调整科目怎么用
  • 服务费可以不退吗
  • 易税是什么
  • 定额发票验旧怎么操作
  • 加盟费收入如何入账
  • 转移性支出与转移性收入相对应主要包括
  • 亏损的递延所得税怎么理解
  • 贷款呆账处理了多长时间恢复征信
  • 分公司是否需要章程
  • 车船税没发票只在备注可以计入管理费用吗
  • 出售原材料属于营业收入吗
  • 带销货清单的专票咋红冲
  • 工资属于劳务收入吗
  • 在windows 7中
  • 苹果macbook 系统
  • php环境配置教程Apace
  • 虚拟存储器什么意思
  • 如何通过路由器查看宽带账号密码
  • 商业成本结转会计分录
  • 其他应付款不用付了怎么做分录
  • 资本溢价和股本差多少
  • 财政补助收入的支付制度包括
  • linux双ip路由设置方法
  • php读取opc
  • php中unlink
  • 税款返还的会计处理方法
  • 永续债进什么科目
  • php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
  • vue页面刷新时原有的数据还在吗
  • vue的一些面试题
  • 为什么说网络安全靠人民
  • 材料采购计入哪个账本
  • 税务三流一致是什么意思
  • 财政补助结转和财政补助结余
  • 公司之间往来款需要交税吗
  • 交通运输企业有什么优惠政策
  • sql查询必须在什么的基础上创建
  • 微信小程序 滚动 变色
  • 劳务报酬的增值税起征点
  • 建筑工程施工围挡安装
  • 银行承兑汇票如果到期了企业没有兑付
  • 为什么运输合肥料检测核辐射人会拿一个玻璃棒
  • ETC通行费发票抵扣2021新规定
  • 租金收入会计科目
  • 营业税金及附加税率
  • 土地补偿费怎么算
  • 接受捐赠的固定资产计入什么科目
  • 农民专业合作社是企业法人吗
  • 记帐凭证会计处理程序及其应用
  • 实例讲解液化滤镜瘦身
  • mysql 隐式游标
  • 储存扩展容量
  • macbook怎么开hdr
  • linux比较两个文件的差异
  • linux系统bug
  • window8系统安装步骤
  • win10预览版21390
  • windows7出现错误恢复怎么办
  • Linux安装完mysql后提示错误无法登陆mysql怎么办?
  • unity项目中的资源
  • 更改uac设置在哪
  • android aidl in out
  • python中读取excel
  • PyCharm在win10的64位系统安装实例
  • unity intercom
  • 最流行的民宿装修设计
  • javascript面向对象编程指南
  • each和each
  • 常用的javascript对象
  • jQuery Ajax 全局调用封装实例代码详解
  • 税控盘的服务费如何申报抵扣
  • 广东省广州市国家税务局
  • 镇江市物业管理协会
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设