IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 数据库--explain的使用 -> 正文阅读

[大数据]数据库--explain的使用

目录

是什么

如何使用

从explain语句能获取哪些信息

怎么分析(各个字段的含义)

(1)id:执行顺序

(2)select_type:查询类型

(3)table:数据来源表

(4)partitions:匹配的分区

(5)type:访问类型

(6)possible_keys

(7)key

(8)key_len

(9)ref

(10)rows

(11)filtered

(12)Extra

使用实例


是什么

可以查看查询语句的执行计划,是查询性能优化的重要工具。

如何使用

explain select * from staffs where name='z3'and age=22 and pos='manager';

从explain语句能获取哪些信息

  • sql语句的执行顺序
  • 数据读取操作的操作类型
  • 哪些索引可能被使用到
  • 哪些索引被实际使用
  • 索引的哪些列被使用到
  • 表之间的引用
  • 每张表有多少行优化器查询

怎么分析(各个字段的含义)

(1)id:执行顺序

id代表SQL语句的执行顺序。

id越大,优先级越高,越先被执行。

id相同,执行顺序由上至下。

id列为null:表示这是一个结果集,不需要使用它来进行查询。

(2)select_type:查询类型

  • SIMPLE:表示简单查询,不包含union和子查询。
  • PRIMARY:表示主查询,查询语句中如果包含子查询,其最外层查询为主查询。
  • SUBQUERY:表示select子句或where子句中的子查询。
  • DERIVED:表示from子句中的子查询。
  • UNION:union语句后的select语句被标记为UNION。
  • UNION RESULT:从union获取结果的select。

(3)table:数据来源表

(4)partitions:匹配的分区

(5)type:访问类型

可用于判断查询是否高效,由优到劣。

system>const?>eq_ref?>ref >index_merge>?range>?index?>ALL

system:表只有一行记录,const类型的特例

const: 针对主键或唯一索引的等值查询扫描,表示通过索引一次就找到了,最多只返回一行数据

eq_ref?:表示联表查询时,按联表的主键或唯一键联合查询

ref: 此类型通常出现在多表的 join 查询,针对于非唯一或非主键索引

range: 表示使用索引范围查询

index: 表示全索引扫描(full index scan),和 ALL 类型类似,只不过 ALL 类型是全表扫描,而 index 类型则仅仅扫描所有的索引, 而不扫描数据

ALL: 表示全表扫描

(6)possible_keys

mysql 在查询时,可能使用到的索引。

(7)key

查询实际使用的哪个索引

(8)key_len

索引使用的字节数。

(9)ref

显示索引的哪一列被使用。

(10)rows

执行查询读取的行数,数值越大表示查询效率越差。(估算值)

(11)filtered

查询的表行占表的百分比

(12)Extra

额外的信息,不适合在其它列显示但十分重要的信息

Using filesort:表示MySQL会对数据使用一个外部的索引排序,而不是按照表内的索引顺序进行读取,MySQL中无法利用索引完成的排序操作称为“文件排序”。
Using temporary:表示使用了临时表存储中间结果,常见于order by和group by子句。
Using index:表示select子句中使用了覆盖索引。
Using where:表示使用了where条件。
Using join buffer:表示使用了连接缓存。
impossible where:表示where子句的值总是false。
distinct:表示发现第一个匹配行后不再继续搜索。

使用实例

可以在数据库中玩一下

?示例sql --包括建表语句

CREATE TABLE staffs(
	id INT PRIMARY KEY AUTO_INCREMENT,
	`name` VARCHAR(24) NOT NULL DEFAULT'' COMMENT'姓名',
	`age` INT NOT NULL DEFAULT 0 COMMENT'年龄',
	`pos` VARCHAR(20) NOT NULL DEFAULT'' COMMENT'职位',
	`add_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT'入职时间'
)CHARSET utf8 COMMENT'员工记录表';
#新增数据
INSERT INTO staffs(`name`,`age`,`pos`,`add_time`) VALUES('z3',22,'manager',NOW());
INSERT INTO staffs(`name`,`age`,`pos`,`add_time`) VALUES('July',23,'dev',NOW());
INSERT INTO staffs(`name`,`age`,`pos`,`add_time`) VALUES('2000',23,'dev',NOW());
#联合索引
ALTER TABLE staffs ADD INDEX index_staffs_nameAgePos(name,age,pos);

CREATE TABLE staffs1(
	id INT PRIMARY KEY AUTO_INCREMENT,
	`name` VARCHAR(24) NOT NULL DEFAULT'' COMMENT'姓名',
	`age` INT NOT NULL DEFAULT 0 COMMENT'年龄',
	`pos` VARCHAR(20) NOT NULL DEFAULT'' COMMENT'职位',
	`add_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT'入职时间'
)CHARSET utf8 COMMENT'员工记录表1';
#新增数据
INSERT INTO staffs1(`name`,`age`,`pos`,`add_time`) VALUES('z3',22,'manager',NOW());
INSERT INTO staffs1(`name`,`age`,`pos`,`add_time`) VALUES('July',23,'dev',NOW());
INSERT INTO staffs1(`name`,`age`,`pos`,`add_time`) VALUES('2000',23,'dev',NOW());
INSERT INTO staffs1(`name`,`age`,`pos`,`add_time`) VALUES('hua',24,'ddd',NOW());
#联合索引
ALTER TABLE staffs1 ADD INDEX index_staffs_nameAgePos(name,age,pos);

#分析  
explain select * from staffs where id = '1';
explain select * from staffs where 1 = 1 group by age;
explain select * from staffs where name='z3'and age=22 and pos='manager';
explain select staffs.name from staffs left join staffs1 on staffs.id = staffs1.id ;
explain select * from staffs where name = (select name from staffs where age =22);
explain select * from staffs where name = 'July' union select * from staffs1 where age =24 ;

参考博文:

数据库 explain详解_萌之兰的博客-CSDN博客_数据库中explain

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-07-21 21:37:17  更:2022-07-21 21:39:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 0:01:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码