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

相关文章

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(