位置: 编程技术 - 正文

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

  • 自然人电子税务报税流程
  • 税务局退给企业的多交的所得税该怎样帐务处理?
  • 工业增加值怎么找
  • 外贸出口企业如何申报增值税
  • 关联交易纳税调整期限
  • 办公家具可以一次性税前扣除吗
  • 税控服务费属于什么费用
  • 土地使用权评估原则
  • 培训发生的差旅费的会计准则有哪些
  • 融资租赁与经营租赁相比具有的优势
  • 增值税留抵还需要交税吗
  • 小规模纳税人公司注销流程及费用
  • 网络技术服务费 税率
  • 工程材料发票备注栏未备注可以进成本吗
  • 行邮税的税率档次
  • 雇佣临时工发生意外能追房东赔偿吗
  • 医院行业类别怎样填写
  • 固定资产折旧年限及残值率
  • 不开票的收入怎么办
  • 未做账务处理
  • 公司购买理财的好处有哪些
  • 超市发购物卡给员工会计分录
  • 生产经营所得投资者减除费用季度申报填吗
  • 公司内部罚款的备注怎么写劳动仲裁
  • 土地长期租赁最长多长时间
  • reg.dll是什么
  • 收回已核销的坏账分录
  • php阿里云oss
  • php sw
  • unipoint
  • br命令怎么用
  • 农业合作社需要纳税吗
  • phpsystem函数
  • pd python
  • 工程服务费税率是多少2023
  • 社会组织志愿者参观泉州华侨历史博物馆
  • 事业单位购入
  • 税务局返还的个税手续费是否纳税
  • 转账手续费没有发票能税前扣除吗
  • 将资产货物用于职工福利
  • 出售未到折旧年金怎么算
  • 固定资产转让开票大类是什么
  • 企业购买的土地计入什么科目
  • 子公司的取得方式
  • 企业风险管理有哪些方面
  • 出售无形资产属什么科目
  • CREATE FUNCTION sqlserver用户定义函数
  • 惠普tpn-c126笔记本
  • xp电脑如何在网页打开
  • 教你设置陌陌耳返
  • windowsserver2008r2密码重置
  • 启动mac问号文件夹闪烁怎么办
  • u盘制作winpe启动盘
  • linux nyy
  • Linux查看文件内容编码
  • centos开机grub
  • win7开启远程设置
  • win10桌面图标无法正常显示
  • 产品密钥需要购买吗
  • win10系统应用和功能中不能卸载
  • 系统自带邮件
  • windows右键不能用了
  • Unity3d_NGUI和UGUI的学习
  • 微信小程序实现文件上传
  • javascript基础编程
  • 梦见擦窗户框
  • unity3d shader之Julia集和Mandelbrot集绘制美丽图案 (二)
  • python itcast
  • python按行写入txt
  • jQuery 中ajax异步调用的四种方式
  • 农产品销售个人所得税
  • 税务官网怎么登录账号
  • 拼多多发票哪里申请开票
  • 加强税务工作
  • 青岛税务社保缴费下载平台
  • 地税局收税标准
  • 上饶税务局电话号码
  • 实名办税人员承诺书范本
  • 非关税壁垒英语翻译
  • 企业演讲稿 英文
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设