MySQL性能分析及explain的使用(转)
explain select * from test1 where id=1;
会出现:
id selecttype table type possible_keys key key_len ref rows extra
其中
- type=const表示通过索引一次就找到了
- key=primary的话,表示使用了主键
- type=all表示为全表扫描
- key=null表示没用到索引
- type=ref因为这时认为是多个匹配行,在联合查询中,一般为ref
假设表有id,key1,key2,key3,把三者形成一个组合索引,则
如:
where key1=.... where key1=1 and key2=2 where key1=3 and key3=3 and key2=2
根据最左原则,这些都是可以使用索引的
如
from test where key1=1 order by key3
用explain分析的话,只用到了normal_key索引,但只对where子句起作用,而后面的order by需要排序
3、使用慢查询分析:
在my.ini中:
long_query_time=1
log-slow-queries=d:\mysql5\logs\mysqlslow.log
把超过1秒的记录在慢查询日志中
可以用mysqlsla来分析之。也可以在mysqlreport中,有如DMS分别分析了select,update,insert,delete,replace等所占的百份比
4、MyISAM和InnoDB的锁定
MyISAM中,注意是表锁来的,比如在多个update操作后,再select时,会发现select操作被锁定了,必须等所有update操作完毕后,再能select
InnoDB的话则不同了,用的是行锁,不存在上面问题。
5、MySQL的事务配置项
innodb_flush_log_at_trx_commit=1
表示事务提交时立即把事务日志写入磁盘,同时数据和索引也更新
innodb_flush_log_at_trx_commit=0
事务提交时,不立即把事务日志写入磁盘,每隔1秒写一次
innodb_flush_log_at_trx_commit=2
事务提交时,立即写入磁盘文件(这里只是写入到内核缓冲区,但不立即刷新到磁盘,而是每隔1秒刷新到盘,同时更新数据和索引)
6、explain用法
explain tbl_name
或:
explain [extended] select select_options
举例:
explain select * from event;
+—-+————-+——-+——+—————+——+———+——+——+——-+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+—-+————-+——-+——+—————+——+———+——+——+——-+
| 1 | SIMPLE | event | ALL | NULL | NULL | NULL | NULL | 13 | |
+—-+————-+——-+——+—————+——+———+——+——+——-+
1 row in set (0.00 sec)
各个属性的含义:
- id
- select查询的序列号
- select_type
- select查询的类型,主要是区别普通查询和联合查询、子查询之类的复杂查询。
 
- table
- 输出的行所引用的表。
 
- type
- 联合查询所使用的类型。
- type显示的是访问类型,是较为重要的一个指标,结果值从好到坏依次是:
- system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL
- 一般来说,得保证查询至少达到range级别,最好能达到ref。
 
- possible_keys
- 指出MySQL能使用哪个索引在该表中找到行。如果是空的,没有相关的索引。这时要提高性能,可通过检验where子句,看是否引用某些字段,或者检查字段不是适合索引。
 
- key
- 显示MySQL实际决定使用的键。如果没有索引被选择,键是null。
 
- key_len
- 显示MySQL决定使用的键长度。如果键是null,长度就是null。文档提示特别注意这个值可以得出一个多重主键里MySQL实际使用了哪一部分。
 
- ref
- 显示哪个字段或常数与key一起被使用。
 
- rows
- 这个数表示MySQL要遍历多少数据才能找到,在InnoDB上是不准确的。
 
- Extra
- 如果是only index,这意味着信息只用索引树中的信息检索出的,这比扫描整个表要快。
- 如果是where used,就是使用上了where限制。
- 如果是impossible where 表示用不着where,一般就是没查出来啥。
- 如果此信息显示using filesort或者using temporary的话会很吃力,where和order by的索引经常无法兼顾,如果按照where来确定索引,那么在order by时,就必然会引起using filesort,这就要看是先过滤再排序划算,还是先排序再过滤划算。
 
- 常见的一些名词解释
- using filesort
- MySQL需要额外的一次传递,以找出如何按排序顺序检索行。
 
- using index
- 从只使用索引树中的信息而不需要进一步搜索读取实际的行来检索表中的列信息。
 
- using temporary
- 为了解决查询,MySQL需要创建一个临时表来容纳结果。
 
- ref
- 对于每个来自于前面的表的行组合,所有有匹配索引值的行将从这张表中读取
 
- all
- 完全没有索引的情况,性能非常地差劲。
 
- index
- 与all相同,除了只有索引树被扫描。这通常比all快,因为索引文件通常比数据文件小。
 
- simple
- 简单select(不使用union或子查询)
 
 
- using filesort
参考:
http://blog.sina.com.cn/s/blog_4586764e0100o9s1.html(以上内容转自此篇文章)
MySQL性能分析及explain的使用(转)的更多相关文章
- MySQL性能分析及explain的使用
		MySQL性能分析及explain用法的知识 1.使用explain语句去查看分析结果 如explain select * from test1 where id=1;会出现:id selectty ... 
- MySQL性能分析及explain的使用说明
		1.使用explain语句去查看分析结果 如explain select * from test1 where id=1;会出现:id selecttype table type possible_k ... 
- mysql 性能分析及explain用法
		转载自http://blog.sina.com.cn/s/blog_4586764e0100o9s1.html 使用explain语句去查看分析结果 如 explain select * from ... 
- MySQL索引,MySQL性能分析及explain的使用,分析SQL查询性能
		可以使用explain来分析MySQL查询性能,举例如下: 1.使用explain语句去查看分析结果 如 explain select * from test1 where id=1; 会出现: id ... 
- MySQL性能分析之Explain
		目录 Explain基础 Explain进阶 Explain基础 关于explain命令相信大家并不陌生,具体用法和字段含义可以参考官网explain-output ,这里需要强调rows是核心指标, ... 
- MySQL性能分析(Explain)
		更多知识,请移步我的小破站:http://hellofriend.top 1. 概述 使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的.分析你的查 ... 
- 神奇的 SQL 之 MySQL 性能分析神器 → EXPLAIN,SQL 起飞的基石!
		前言 开心一刻 某人养了一头猪,烦了想放生,可是猪认识回家的路,放生几次它都自己回来了.一日,这个人想了个狠办法,开车带着猪转了好多路进山区放生,放生后又各种打转,然后掏出电话给家里人打了个电话,问道 ... 
- mysql性能分析之explain的用法
		之前是一直没有听过explain这个关键字的, 最近因为项目中总是会有慢查询的一些操作, 所以请教了旁边的同事帮忙排查下原因, 看到同事用explain来分析一些sql语句, 感觉好像发现了新大陆一样 ... 
- MySQL性能分析, mysql explain执行计划详解
		MySQL性能分析 MySQL性能分析及explain用法的知识是本文我们主要要介绍的内容,接下来就让我们通过一些实际的例子来介绍这一过程,希望能够对您有所帮助. 1.使用explain语句去查看分析 ... 
随机推荐
- Numpy 系列(九)-  结构化数组
			简介 之前我们操作Numpy的数组时,都是通过索引来操作的.针对二维数组,使用索引可以完成对行.列的操作.但是这是非常不直观的.可以把二维数组想象成一个excel表格,如果表格没有列名,操作起来会 ... 
- 机器学习 - 正则化L1 L2
			L1 L2 Regularization 表示方式: $L_2\text{ regularization term} = ||\boldsymbol w||_2^2 = {w_1^2 + w_2^2 ... 
- spring定时任务详解(@Scheduled注解)
			Spring配置文件xmlns加入 xmlns:task="http://www.springframework.org/schema/task" xsi:schemaLocati ... 
- EF CodeFirst系列(8)--- FluentApi配置单个实体
			我们已经知道了在OnModelCreating()方法中可以通过FluentApi对所有的实体类进行配置,然而当实体类很多时,我们把所有的配置都放在OnModelCreating()方法中很难维护.E ... 
- nnet3配置中的上下文和chunk(块)大小
			Nnet3配置中的上下文和块大小 简介 本页讨论了nnet3配置中关于解码和训练的块大小以及左右上下文的某些术语.这将有助于理解一些脚本.目前,从脚本角度来看,没有任何关于nnet3的"概述 ... 
- git 20181119
			不同分支间(a.b分支)合并部分文件 git ck b git ck a f1 f2 git配置 配置文件 系统git config --system --list 全局git config --gl ... 
- monkey测试 -- 原理和操作步骤
			Monkey测试原理: Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中.它向系统发送伪随机的用户事件流(如按键输入.触摸屏输入.手势输入等),实现对正在开发的应用程序 ... 
- 第六章 使用 Bootstrap Typeahead 组件(百度下拉效果)(续)
			官方:http://twitter.github.io/typeahead.js/ 示例:http://twitter.github.io/typeahead.js/examples/(本文展示:Op ... 
- [Ynoi2018]末日时在做什么?有没有空?可以来拯救吗?
			这道题真的超级...毒瘤 + 卡常 + 耗 RP 啊... 传送门 noteskey 题解看 shadowice 大仙 的 code 如果发现自己 T 掉了,别心急,洗把脸再交一遍试试... //by ... 
- 18 常用模块 random shutil shevle logging sys.stdin/out/err
			random:随机数 (0, 1) 小数:random.random() ***[1, 10] 整数:random.randint(1, 10) *****[1, 10) 整数:random.rand ... 
