执行计划--mysql详解(七)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 执行计划--mysql详解(七)

上篇文章说了,mysql优化器会从cpuio成本来考虑查询的消耗,possible key来计算全表和索引的成本,选择成本最小的,子查询有物化和semi-join半连接的方式优化,物化会优先哈希索引memory存储引擎,如果数据量太大会选择b+树。

Mysql优化器-mysql详解(六)


Mysql在计算成本之后生成执行计划,用explain来查看,会返回很多列。

Table:查询的表名称,查询几张表显示几行。

Id:正常情况下是有几个select就会显示几行,但是id的序号是从1开始,

如果是连接查询(包含内连接外连接),会显示两行,且都是id1,并且再说上面的是驱动表。

如果是子查询,也会显示两行,但id会是12,但凡是有例外,前面说过mysql优化器会优化子查询优化成半连接,这时候我们如何知道他是物化还是优化成半连接呢,可以通过id来判断,如果id一致,则和上面的连接查询一样,代表子查询优化成了连接查询。

还有union语句,会有一个union Result,因为union会去重,去重就是临时表来用唯一建去重,这时候临时表就会显示union Resultunion all没有,原因就是all不需要去重。

Select type:主要

Simple:单表或者连接查询。

Primaryunion:有union语句存在的时候。

Subquery:子查询的时候。

Derived:派生查询的时候。

Materialzed:当不能半连接,就物化查询的时候。

Partitions:分区,一般是null,除非我们设置了分区。

Type:第一个是system,当表里只有一条数据,并且是精确计算的时候(myISAMmemory),后面就是我们前面说过的constrefref_nullrangeindexall

Possible key:就是我们前面说的mysql优化器在选择执行计划之前,会先把所有可能用到的索引全部计算一下成本。

Key:真实用到的索引。

Key_lenth:索引的长度,会根据变长字符集来计算。

Ref:在等值条件下执行的时候,ref会显示const

Rows:实际扫描多少数据才获取到结果集。

Filtered(百分比):

当单表查询的时候,有两个查询条件,则是rows*fltered%,表示满足第二个条件的数据。

当连接查询的时候,则代表前面说的扇出值,驱动表扇出值计算为被驱动表需要执行的次数。

Extra

比如写错sql会报错no tables used

where后面语句写错或者永远为false时候报错impossible where

当聚合函数写错报错no matching min/max row

当使用覆盖索引的时候,会显示user index

Explain format=json 可以返回json数据,并且可以看到执行这个sql的成本。

还可以在执行完之后,执行show warnings会看到mysql优化器优化后的sql语句。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
17天前
|
缓存 关系型数据库 MySQL
MySQL执行计划选择策略:揭秘查询优化的艺术
【10月更文挑战第15天】 在数据库性能优化中,选择最优的执行计划是提升查询效率的关键。MySQL作为一个强大的关系型数据库管理系统,提供了复杂的查询优化器来生成执行计划。本文将深入探讨如何选择合适的执行计划,以及为什么某些计划更优。
36 2
|
17天前
|
缓存 关系型数据库 MySQL
MySQL执行计划深度解析:如何做出最优选择
【10月更文挑战第23天】 在数据库查询性能优化中,执行计划的选择至关重要。MySQL通过查询优化器来生成执行计划,但有时不同的执行计划会导致性能差异。理解如何选择合适的执行计划,以及为什么某些计划更优,对于数据库管理员和开发者来说是一项必备技能。
28 2
|
17天前
|
SQL 关系型数据库 MySQL
美团面试:Mysql如何选择最优 执行计划,为什么?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴面试美团时遇到了关于MySQL执行计划的面试题:“MySQL如何选择最优执行计划,为什么?”由于缺乏系统化的准备,小伙伴未能给出满意的答案,面试失败。为此,尼恩为大家系统化地梳理了MySQL执行计划的相关知识,帮助大家提升技术水平,展示“技术肌肉”,让面试官“爱到不能自已”。相关内容已收录进《尼恩Java面试宝典PDF》V175版本,供大家参考学习。
|
2月前
|
SQL 存储 关系型数据库
深入 MySQL 的执行计划与性能优化
深入 MySQL 的执行计划与性能优化
39 0
|
5月前
|
SQL 关系型数据库 MySQL
【Mysql】 深入理解MySQL的执行计划
【Mysql】 深入理解MySQL的执行计划
247 4
|
5月前
|
SQL 关系型数据库 MySQL
MySQL数据库——索引(4)-SQL性能分析-profile详情、explain(profile查看指令,explain执行计划中各个字段的含义)
MySQL数据库——索引(4)-SQL性能分析-profile详情、explain(profile查看指令,explain执行计划中各个字段的含义)
63 2
|
6月前
|
SQL 算法 关系型数据库
从执行计划了解MySQL优化策略
从执行计划了解MySQL优化策略
81 0
从执行计划了解MySQL优化策略
|
6月前
|
关系型数据库 MySQL 数据库
mysq优化---mysql执行计划解释、优化查询、数据库结构、服务器
mysq优化---mysql执行计划解释、优化查询、数据库结构、服务器
|
6月前
|
存储 关系型数据库 MySQL
MySQL查询执行计划详解(EXPLAIN)
一、单表查询 访问方法/访问类型: • const:通过主键值或唯一二级索引与一个常熟进行等值查询(不包括NULL),只会生成一条记录 • ref:普通二级索引与一个常数进行等值比较,可能生成多条记录 • ref_or_null:ref的前提下可以加上or key is null • range:对应的扫描区间为若干个单点扫描区间或范围扫描区间(不包括负无穷到正无穷的范围) • index:扫描区间为全表,但是可以在二级索引中扫描(因为二级索引每条记录占用空间更小,所以需要读的页更少) • all:直接扫描全部的聚集索引记录
|
关系型数据库 MySQL 索引
Mysql的执行计划explain
Mysql的执行计划explain
58 0