`

查询到效率低的 SQL 语句 后,可以通过 EXPLAIN 或者 DESC 命令获取 MySQL 如何执行 SELECT 语句的信息,包括在 SELECT 语句

    博客分类:
  • myql
阅读更多

原文作者:http://home198979.iteye.com/blog/1442551

查询到效率低的 SQL 语句 后,可以通过 EXPLAIN 或者 DESC 命令获取 MySQL 如何执行 SELECT 语句的信息,包括在 SELECT 语句执行过程中表如何连接和连接的顺序,比如我们想计算 2006 年所有公司的销售额,需要关联 sales 表和 company 表,并且对 profit 字段做求和( sum )操作,相应 SQL 的执行计划如下: 
mysql> explain select sum(profit) from sales a,company b where a.company_id = b.id and a.year = 2006\G; 
*************************** 1. row *************************** 
id: 1 
select_type: SIMPLE 
table: a 
type: ALL 
possible_keys: NULL 
key: NULL 
key_len: NULL 
ref: NULL 
rows: 12 
Extra: Using where 
*************************** 2. row *************************** 
id: 1 
select_type: SIMPLE 
table: b 
type: ALL 
possible_keys: NULL 
key: NULL 
key_len: NULL 
ref: NULL 
rows: 12 
Extra: Using where 
2 rows in set (0.00 sec) 
每个列的解释如下: 

select_type :表示 SELECT 的 类型,常见的取值有 SIMPLE (简单表,即不使用表连接或者子查询)、 PRIMARY (主查询,即外层的查询)、 UNION ( UNION 中的第二个或者后面的查询语句)、 SUBQUERY (子查询中的第一个 SELECT )等。 
table :输出结果集的表。 
type :表示表的连接类型,性能由好到差的连接类型为 system (表中仅有一行,即常量表)、 const (单表中最多有一个匹配行,例如 primary key 或者 unique index )、 eq_ref (对于前面的每一行,在此表中只查询一条记录,简单来说,就是多表连接中使用 primary key 或者 unique index )、 ref (与 eq_ref 类似,区别在于不是使用 primary key 或者 unique index ,而是使用普通的索引)、 ref_or_null ( 与 ref 类似,区别在于条件中包含对 NULL 的查询 ) 、 index_merge ( 索引合并优化 ) 、 unique_subquery ( in 的后面是一个查询主键字段的子查询)、 index_subquery ( 与 unique_subquery 类似,区别在于 in 的后面是查询非唯一索引字段的子查询)、 range (单表中的范围查询)、 index (对于前面的每一行,都通过查询索引来得到数据)、 all (对于前面的每一行,都通过全表扫描来得到数据)。 
possible_keys :表示查询时,可能使用的索引。 
key :表示实际使用的索引。 
key_len :索引字段的长度。 
rows :扫描行的数量。 
Extra :执行情况的说明和描述。 

在上面的例子中,已经可以确认是 对 a 表的全表扫描导致效率的不理想,那么 对 a 表的 year 字段创建索引,具体如下: 
mysql> create index idx_sales_year on sales(year); 
Query OK, 12 rows affected (0.01 sec) 
Records: 12 Duplicates: 0 Warnings: 0 
创建索引后,这条语句的执行计划如下: 
mysql> explain select sum(profit) from sales a,company b where a.company_id = b.id and a.year = 2006\G; 
*************************** 1. row *************************** 
id: 1 
select_type: SIMPLE 
table: a 
type: ref 
possible_keys: idx_sales_year 
key: idx_sales_year 
key_len: 4 
ref: const 
rows: 3 
Extra: 
*************************** 2. row *************************** 
id: 1 
select_type: SIMPLE 
table: b 
type: ALL 
possible_keys: NULL 
key: NULL 
key_len: NULL 
ref: NULL 
rows: 12 
Extra: Using where 
2 rows in set (0.00 sec) 
    可以发现建立索引后对 a 表需要扫描的行数明显减少(从全表扫描减少到 3 行),可见索引的使用可以大大提高数据库的访问速度,尤其在表很庞大的时候这种优势更为明显,使用索引优化 sql 是优化问题 sql 的一种常用基本方法,在后面的章节中我们会具体介绍如何使索引来优化 sql 。

分享到:
评论

相关推荐

    MySQL优化之如何查找SQL效率低的原因

    查询到效率低的 SQL 语句 后,可以通过 EXPLAIN 或者 DESC 命令获取 MySQL 如何执行 SELECT 语句的信息,包括在 SELECT 语句执行过程中表如何连接和连接的顺序,比如我们想计算 2006 年所有公司的销售额,需要关联 ...

    基于mysql的sql语句学习与练习

    本文将深入探讨基于MySQL的SQL语句,帮助你掌握数据操作、查询、管理及优化的基础知识。 一、SQL基础 SQL,全称为结构化查询语言,是用于管理关系数据库的标准语言。在MySQL中,SQL主要包括以下几个基本部分: 1....

    MySQL练习代码, sql语句练习2

    本资料包含的是"SQL语句练习2",旨在帮助用户深入理解和熟练掌握MySQL中的SQL查询语言。 SQL(Structured Query Language),结构化查询语言,是用于管理和处理关系数据库的标准语言。在“SQL语句练习2”中,我们...

    分析Mysql表读写、索引等操作的sql语句效率优化问题.doc

    通过这些数据,我们可以定位到执行频率高但效率低的操作,对SQL语句进行优化。 对于索引的优化,应确保经常使用的WHERE子句中的字段都有对应的索引。可以使用`EXPLAIN`关键字来分析查询计划,检查是否使用了索引,...

    Java面试SQL查询语句突击练习

    1. **基本查询**:包括SELECT语句,用于从表中获取数据。如`SELECT * FROM table_name`可以获取表中的所有记录。你可以通过指定字段名来选择需要的部分,或者使用WHERE子句进行条件筛选。 2. **聚合函数**:如COUNT...

    MySQL命令行和语句(共28页word文档,涵盖26大项sql操作,几乎所有需要的操作都在这里)

    通过`SHOW VARIABLES`命令可以获取MySQL服务器的系统变量设置情况: ```sql SHOW VARIABLES; ``` #### 二、数据库操作 - **查看当前使用的数据库** 使用`SELECT DATABASE()`可以返回当前正在使用的数据库名称...

    mysql面试题-查询语句

    1. **基本查询**:这包括使用SELECT语句从一个或多个表中检索数据。基础查询涉及指定列名、表名,以及WHERE子句来过滤结果。例如,`SELECT column1, column2 FROM table WHERE condition`。 2. **聚合函数**:诸如...

    sql基础与优化吐血整理

    2. 查询缓存:虽然MySQL 8.0已移除此功能,但在之前的版本中,如果相同的查询语句再次被执行,可以从缓存中直接返回结果,避免重新计算。 3. 分析器:解析SQL语句,确定其意图并检查语法。优化时应确保语句清晰无误...

    分析Mysql表读写、索引等操作的sql语句效率优化问题

    在MySQL数据库管理中,SQL语句的效率优化是至关重要的,尤其对于大型系统而言,这直接影响到系统的响应时间和整体性能。今天我们将深入探讨如何分析MySQL表的读写、索引等操作,以及如何通过SQL语句进行效率优化。 ...

    mysql查询gitbook书籍

    12. **存储过程**:预编译的SQL语句集合,可以包含复杂的逻辑,可被多次调用。 13. **事务处理**:确保数据库操作的原子性、一致性、隔离性和持久性(ACID属性),保障数据完整性。 14. **分区表**:大型表可以被...

    mysql 基本命令,及java中访问mysql

    - **查询优化**:通过EXPLAIN分析查询计划,优化SQL语句,提高查询效率。 这些只是MySQL和Java数据库交互的基本概念和命令,实际使用中还有更多高级特性,如触发器、函数、游标等,都需要根据具体需求进行学习和...

    【MySQL】SQL性能分析 (七).pdf

    - `EXPLAIN`或`DESC`命令用于显示MySQL如何执行SELECT语句的详细信息,包括连接顺序和使用的索引等。这对于评估查询的执行效率非常有帮助。 - **使用语法**: - 基本格式为:`EXPLAIN SELECT ... FROM ... WHERE ....

    Mysql的数据集 Mysql的数据集 Mysql的数据集

    MySQL 数据集是数据库管理系统中一个重要的概念,它指的是在 SQL 查询语句中形成的临时或永久性的数据集合。在本篇文章中,我们将深入探讨 MySQL 数据集的相关知识点,包括数据集的生成、操作以及优化策略。 首先,...

    MySQL的基本命令

    - **使用`EXPLAIN`**:分析查询执行计划,检查索引是否被正确使用,从而优化查询效率。 通过以上介绍,我们了解了MySQL中基本命令的重要性和具体用法,同时也学习了如何通过合理的索引设计和优化策略来提升查询性能...

    mysql进阶学习

    开发者需要了解如何使用 EXPLAIN 语句来分析查询语句,了解查询的执行计划,优化查询效率。 索引优化 索引优化是 MySQL 进阶学习的重要组成部分。开发者需要了解如何创建合适的索引,提高查询效率,减少数据库负载...

    MySQL中EXPLAIN命令详解

    使用方法,在select语句前加上explain就可以了: 如: mysql> explain select * from kt_course order by create_time desc; +----+-------------+-----------+------+---------------+------+---------+------+---...

    sql语句大全

    - `PREPARE`:预编译SQL语句,提高执行效率。 - `EXECUTE`:执行预编译的SQL语句。 - `DESCRIBE`:描述预编译的查询结构。 6. **流程控制**: - `IF-ELSE`:条件判断,根据条件执行不同的代码块。 - `CASE`:...

    Mysql查询最近一条记录的sql语句(优化篇)

    对于需要批量查询多个用户最近记录的情况,例如获取所有用户的最新订单,每个用户都要执行一次完整的表扫描,效率极低。 接下来,我们可以使用`GROUP BY`来优化查询。首先,对数据进行排序,然后按用户ID分组,返回...

    mysql常用数据库命令

    - 可以使用 `explain` 关键字来分析 SQL 查询的执行计划,进而优化查询语句。 - **管理用户和权限**: - 可以使用 `grant` 和 `revoke` 来管理用户的权限。 以上就是 MySQL 数据库中的一些常用命令和操作。这些...

    MySQL命令.docx

    通过`EXPLAIN`关键字来分析SQL语句的执行计划,判断索引是否被正确利用。 10. **删除索引**: ```sql DROP INDEX 索引名称 ON 表名称; ``` 删除不再需要的索引以减少维护成本。 11. **查看表结构**: ```sql...

Global site tag (gtag.js) - Google Analytics