≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > MySQL

MySQL中explain语句用法示例

人气:253 时间:2021-07-08

这篇文章主要为大家详细介绍了MySQL中explain语句用法示例,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小玲来看看吧!

目录
  • 一、概述
    • 1、explain语句测试
    • 2、explain结果中各列的说明
  • 二、explain之id列
    • 1、环境准备
    • 2、explain中的id列详解
  • 三、explain之select_type列
    • 1、select_type
    • 3、PRIMARY、SUBQUERY
    • 4、DERIVED
    • 5、UNION、UNION RESULT
  • 四、explain之table、type列
    • 1、table列
    • 2、type列
    • 3、例
    • (1) NULL
    • (2) system
    • (3) const
    • (4) eq_ref
    • (5) ref
    • (6) index
    • (7) ALL
  • 五、explain之key、rows、extra列
    • 1、key
    • 2、rows
  • 总结

 

一、概述

在 MySQL 中,我们可以使用慢查询日志或者 show processlist 命令等方式定位到执行耗时较长的 SQL 语句,在这之后我们可以通过 EXPLAIN或者 DESC 命令获取 MySQL 如何执行 SELECT 语句 的信息,包括在 SELECT 语句执行过程中表如何连接和连接的顺序

 

1、explain语句测试

explain+select语句即 explain 命令的使用方式

 

2、explain结果中各列的说明

下面,将对这些列逐一进行讲解

 

二、explain之id列

 

1、环境准备


 

2、explain中的id列详解

id 字段是 select 查询的序列号,是一组数字,表示的是查询中执行 select 子句或者是操作表的顺序。id 情况有三种
(1) id 相同表示加载表的顺序是从上到下

(2) id 不同id值越大,优先级越高,越先被执行

(3) id 有相同,也有不同,同时存在。id相同的可以认为是一组,从上往下顺序执行;在所有的组中,id的值越大,优先级越高,越先执行。

 

三、explain之select_type列

 

1、select_type

2、

SIMPLE

 

3、PRIMARY、SUBQUERY

 

4、DERIVED

 

5、UNION、UNION RESULT

 

四、explain之table、type列

 

1、table列

table列展示该行数据属于哪张表

 

2、type列

type列显示的是访问类型

 

3、例

 

(1) NULL

 

(2) system

 

(3) const

 

(4) eq_ref

 

(5) ref

 

(6) index

 

(7) ALL

 

五、explain之key、rows、extra列

 

1、key


 

2、rows

扫描行的数量

如果有索引,就只扫描一行

3、extra

 

总结

到此这篇关于MySQL中explain语句的基本使用教程的文章就介绍到这了,更多相关MySQL中explain使用内容请搜索四海网以前的文章或继续浏览下面的相关文章希望大家以后多多支持四海网!

本文来自:http://www.q1010.com/177/19304-0.html

注:关于MySQL中explain语句用法示例的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:

您可能感兴趣的文章

上一篇:MySQL source命令用法示例
下一篇:解决MySQL锁等待与死锁的问题
热门文章
  • mysql 修改character_set_server为utf-8的简单示例
  • 解决MySQL丢失文件localhost.localdomain.pid、mysql.sock的示例
  • MySQL 数据类型binary和varbinary的简单示例
  • MySQL:reading initial communication packet问题解决方法
  • MySql 表类型MYISAM、InnoDB区别
  • bash: mysql: command not found 的解决方法
  • MYSQL默认用户名ROOT修改方法
  • MySQL 常用命令菜鸟教程
  • MySQL 使用命令行新建用户并授予权限
  • MySql 数据库物理文件存放位置查看示例
  • 最新文章
    • MySQL查看死锁与解除死锁的简单示例
    • MySQL 慢查询的功能实例
    • MySQL查看死锁与去除死锁的简单示例
    • MySQL找出未提交事务的SQL的简单示例
    • MySQL锁阻塞的的简单示例
    • MySQL中的binary类型使用操作的示例
    • SQL优化教程之in与range查询的简单示例
    • MySQL 的 21 个规范、优化最佳实践!
    • MySQL 字符类型大小写敏感的简单示例
    • 解决mybatis-plus分页传入参数后sql where条件没有limit分页信息的问题

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。