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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 执行计划--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语句。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
SQL 关系型数据库 MySQL
MySQL视图、索引、备份与恢复、执行计划(三)
MySQL视图、索引、备份与恢复、执行计划(三)
41 0
|
2天前
|
关系型数据库 MySQL 数据库
mysq优化---mysql执行计划解释、优化查询、数据库结构、服务器
mysq优化---mysql执行计划解释、优化查询、数据库结构、服务器
|
2天前
|
SQL 算法 关系型数据库
从执行计划了解MySQL优化策略
从执行计划了解MySQL优化策略
56 0
从执行计划了解MySQL优化策略
|
2天前
|
存储 关系型数据库 MySQL
MySQL查询执行计划详解(EXPLAIN)
一、单表查询 访问方法/访问类型: • const:通过主键值或唯一二级索引与一个常熟进行等值查询(不包括NULL),只会生成一条记录 • ref:普通二级索引与一个常数进行等值比较,可能生成多条记录 • ref_or_null:ref的前提下可以加上or key is null • range:对应的扫描区间为若干个单点扫描区间或范围扫描区间(不包括负无穷到正无穷的范围) • index:扫描区间为全表,但是可以在二级索引中扫描(因为二级索引每条记录占用空间更小,所以需要读的页更少) • all:直接扫描全部的聚集索引记录
|
6月前
|
关系型数据库 MySQL 索引
Mysql的执行计划explain
Mysql的执行计划explain
32 0
|
8月前
|
存储 关系型数据库 MySQL
MySQL视图、索引、备份与恢复、执行计划(二)
MySQL视图、索引、备份与恢复、执行计划(二)
51 0
|
8月前
|
存储 关系型数据库 MySQL
MySQL视图、索引、备份与恢复、执行计划(一)
MySQL视图、索引、备份与恢复、执行计划
50 0
|
8月前
|
SQL 存储 关系型数据库
一文读懂 MySQL Explain 执行计划
一文读懂 MySQL Explain 执行计划
152 0
|
9月前
|
存储 关系型数据库 MySQL
MySQL基础应用拓展、索引及执行计划
MySQL基础应用拓展、索引及执行计划
63 0
MySQL基础应用拓展、索引及执行计划
|
9月前
|
SQL 算法 关系型数据库
【MySQL进阶-02】mysql的explain执行计划以及索引优化
【MySQL进阶-02】mysql的explain执行计划以及索引优化
86 0

推荐镜像

更多