Mysql 查询优化器之派生条件回移Derived Condition Pushdown详解

本文主要是介绍Mysql 查询优化器之派生条件回移Derived Condition Pushdown详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Mysql 优化器之派生条件回移Derived Condition Pushdown详解

派生条件回移优化概述

Mysql 8.0.22之后的版本支持派生条件回移(Derived Condition Pushdown)优化。该优化可以减少派生表处理的行数从而提高查询执行的效率。比方说有如下查询:

SELECT * FROM 
(SELECT i, j FROM t1) AS dt 
WHERE i > constant

通过派生条件回移优化后类似如下形式(WHERE条件拿到派生表的里面):

SELECT * FROM (SELECT i, j FROM t1 WHERE i > constant)

派生条件回移应用示例

派生表里无分组条件

当派生表里没有分组函数时,派生表外的WHERE条件可以直接拿到派生表内。当然WHERE条件如果包含AND、OR等组合条件也是可以回移的。

见下例:

SELECT * FROM
(SELECT f1, f2 FROM t1) AS d
WHERE f1 < 3 AND f2 > 11 

回移优化法:

SELECT f1, f2 FROM
(SELECT f1, f2 FROM t1 WHERE f1 < 3 AND f2 > 11)
AS d

派生表里分组对应非分组字段

当派生表里有GROUP BY语句但没有用到窗口函数时,外部的WHERE条件引用派生表里的字段(不是分组字段)时等效于在派生表里写成HAVING的形式。

示例查询:

SELECT * FROM (SELECT i, j, SUM(k) AS sum FROM t1 GROUP BY i, j) AS dt
WHERE sum > 100 

回移优化法:

SELECT * FROM (
SELECT i, j, SUM(k) AS sum
FROM t1 GROUP BY i, j
HAVING sum > 100) AS dt

派生表里分组对应分组字段

当派生表里有GROUP BY语句但没有用到窗口函数时,外部的WHERE条件引用派生表里的字段(是分组字段)时等效于在派生表里写成WHERE的形式。

SELECT * FROM (SELECT i,j, SUM(k) AS sum FROM t1 GROUP BY i,j) AS dt WHERE i > 10 

回移优化法:

SELECT * FROM (SELECT i,j, SUM(k) AS sum FROM t1 WHERE i > 10 GROUP BY i,j) AS dt

派生表里分组对应分组非分组字段

同理如果WHERE条件里既用到派生表的分组字段又用到非分组字段,则可以提到派生表内改成对应的WHERE和HAVING条件。

示例语句:

SELECT * FROM (SELECT i, j, SUM(k) AS sum FROM t1 GROUP BY i,j) AS dt WHERE i > 10 AND sum > 100

回移优化法:

SELECT * FROM (SELECT i, j, SUM(k) AS sum FROM t1WHERE i > 10GROUP BY i, jHAVING sum > 100
) AS dt;

派生条件回移应用的限制

  1. 派生表里有UNION关键字时,该优化法不适用。
  2. 派生表里有LIMIT关键字时,该优化法不适用。
  3. WHERE条件包含子查询时不能回移。
  4. 如果派生表是和外部进行外连接的不能回移。
  5. 如果物化派生表是公共表达式(CTE)且被引用多次则WHERE条件不能回移。
  6. 如果WHERE 条件里是derived_column > ?( 这里的?即对应某个参数)时可以回移。但当WHERE条件里用表达式结合?时则不能回移。

查看优化切换参数的设置

show VARIABLES LIKE '%optimizer_switch%'
Variable_name	Value
optimizer_switch	index_merge=on
index_merge_union=on
index_merge_sort_union=on
index_merge_intersection=on
engine_condition_pushdown=on
index_condition_pushdown=on
mrr=on
mrr_cost_based=on
block_nested_loop=on
batched_key_access=off
materialization=on
semijoin=on
loosescan=on
firstmatch=on
duplicateweedout=on
subquery_materialization_cost_based=on
use_index_extensions=on
condition_fanout_filter=on
derived_merge=on
use_invisible_indexes=off
skip_scan=on
hash_join=on
subquery_to_derived=off
prefer_ordering_index=on
hypergraph_optimizer=off
derived_condition_pushdown=on

这篇关于Mysql 查询优化器之派生条件回移Derived Condition Pushdown详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/438711

相关文章

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Spring Cache注解@Cacheable的九个属性详解

《SpringCache注解@Cacheable的九个属性详解》在@Cacheable注解的使用中,共有9个属性供我们来使用,这9个属性分别是:value、cacheNames、key、key... 目录1.value/cacheNames 属性2.key属性3.keyGeneratjavascriptor

PyTorch中cdist和sum函数使用示例详解

《PyTorch中cdist和sum函数使用示例详解》torch.cdist是PyTorch中用于计算**两个张量之间的成对距离(pairwisedistance)**的函数,常用于点云处理、图神经网... 目录基本语法输出示例1. 简单的 2D 欧几里得距离2. 批量形式(3D Tensor)3. 使用不

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

Nginx 413修改上传文件大小限制的方法详解

《Nginx413修改上传文件大小限制的方法详解》在使用Nginx作为Web服务器时,有时会遇到客户端尝试上传大文件时返回​​413RequestEntityTooLarge​​... 目录1. 理解 ​​413 Request Entity Too Large​​ 错误2. 修改 Nginx 配置2.1

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

Java 的 Condition 接口与等待通知机制详解

《Java的Condition接口与等待通知机制详解》在Java并发编程里,实现线程间的协作与同步是极为关键的任务,本文将深入探究Condition接口及其背后的等待通知机制,感兴趣的朋友一起看... 目录一、引言二、Condition 接口概述2.1 基本概念2.2 与 Object 类等待通知方法的区别

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

Java实例化对象的​7种方式详解

《Java实例化对象的​7种方式详解》在Java中,实例化对象的方式有多种,具体取决于场景需求和设计模式,本文整理了7种常用的方法,文中的示例代码讲解详细,有需要的可以了解下... 目录1. ​new 关键字(直接构造)​2. ​反射(Reflection)​​3. ​克隆(Clone)​​4. ​反序列化