MYSQL: Handler_read_%参数说明
表t_feed_idx(user_id bigint, feed_id bigint, KEY (`user_id`,`feed_id`)) engine=innodb;
表t_feed_info(feed_id bigint, PRIMARY KEY (`feed_id`), '其他列') engine=innodb;feed 总数 : 100000用户(ID:20000001) feed 数 : 200
查询
######### 单表
> 全部扫描
EXPLAIN SELECT * FROM `t_feed_info` AS i ORDER BY NULL LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i ALL \\N \\N \\N \\N 98734
Handler_read_first + 1 : 从(主)键的第一个位置开始读取
Handler_read_key + 1 : 根据第一个位置的KEY读1行,其他9行是根据叶节点的链表依次读取
Handler_read_rnd_next +10 : 从主键的叶节点(行数据)中顺序读取10行
> 索引扫描
EXPLAIN SELECT * FROM `t_feed_info` AS i ORDER BY feed_id LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i index \\N PRIMARY 8 \\N 10
Handler_read_first + 1 : 从(主)键的第一个位置开始读取
Handler_read_key + 1 : 根据第一个位置的KEY读1行
Handler_read_next + 9 : 按(主)键顺序依次读取之后的9行
EXPLAIN SELECT * FROM `t_feed_info` AS i ORDER BY feed_id DESC LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i index \\N PRIMARY 8 \\N 10
Handler_read_key + 1 : 根据第一个位置的KEY读1行
Handler_read_last + 1 : 从(主)键的最后一个位置开始读取
Handler_read_prev + 9 : 按(主)键顺序依次读取之前的9行
> 索引覆盖扫描
EXPLAIN SELECT feed_id FROM `t_feed_info` AS i ORDER BY feed_id LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i index \\N PRIMARY 8 \\N 10 Using index
Handler_read_first + 1 : 从(主)键的第一个位置开始读取
Handler_read_key + 1 : 根据第一个位置的KEY读1行
Handler_read_next + 9 : 按(主)键顺序依次读取之后的9行
EXPLAIN SELECT feed_id FROM `t_feed_info` AS i ORDER BY feed_id DESC LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i index \\N PRIMARY 8 \\N 10 Using index
Handler_read_key + 1 : 根据第一个位置的KEY读1行
Handler_read_last + 1 : 从(主)键的最后一个位置开始读取
Handler_read_prev + 9 : 按(主)键倒序依次读取之后的9行
############### join
# set @uid := '20000001';
# asc
EXPLAIN SELECT * FROM `t_feed_idx` AS i
LEFT JOIN `t_feed_info` AS f ON f.`feed_id`=i.`feed_id`
WHERE i.user_id=@uid ORDER BY i.feed_id LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i ref user_id user_id 8 const 200 Using where; Using index
- 1 SIMPLE f eq_ref PRIMARY PRIMARY 8 z3.i.feed_id 1
Handler_read_key + 11 : t_feed_idx 根据user_id读1次,t_feed_info根据feed_id读10次
Handler_read_next + 9 : t_feed_idx按键顺序依次向后读取9个feed_id
EXPLAIN SELECT * FROM `t_feed_idx` AS i
LEFT JOIN `t_feed_info` AS f ON f.`feed_id`=i.`feed_id`
WHERE i.user_id=@uid ORDER BY i.feed_id desc LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i ref user_id user_id 8 const 200 Using where; Using index
- 1 SIMPLE f eq_ref PRIMARY PRIMARY 8 z3.i.feed_id 1
Handler_read_key + 11 : t_feed_idx 根据user_id读1次,t_feed_info根据feed_id读10次
Handler_read_prev + 9 : t_feed_idx按键倒序依次向前读取9个feed_id
# 不好的查询方式:
> 使用被关联表t_feed_info的feed_id列进行排序
LEFT JOIN `t_feed_info` AS f ON f.`feed_id`=i.`feed_id`
WHERE i.user_id=@uid ORDER BY f.feed_id LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i ref user_id user_id 8 const 200 Using index; Using temporary; Using filesort
- 1 SIMPLE f eq_ref PRIMARY PRIMARY 8 z3.i.feed_id 1
Handler_read_key + 201 : t_feed_idx 根据user_id读1次,t_feed_info根据feed_id读200次
Handler_read_next + 200 : t_feed_idx按键顺序依次读取199个feed_id. 额外的1次是??
Handler_read_rnd + 10 : filesort后每行位置都是固定的,limit 10取10行
Handler_read_rnd_next + 201: filesort全表遍历读取temporary表中的200行,进行排序; 额外的1是EOF标志位;
Using temporary; Using filesort 原因: 无法使用t_feed_idx表的索引
1>先查询表t_feed_idx中满足@uid的200行与表t_feed_info进行join,将结果保存在temporary表
Handler_read_key + 201, Handler_read_next + 200
2>然后对临时表排序;
Handler_read_rnd_next + 201
3>取前10个。
Handler_read_rnd + 10
> where条件放在join中
LEFT JOIN `t_feed_info` AS f ON f.`feed_id`=i.`feed_id` AND i.user_id=@uid
ORDER BY i.`feed_id` DESC LIMIT 0, 10;
点击(此处)折叠或打开
- id select_type table type possible_keys key key_len ref rows Extra
- 1 SIMPLE i index \\N user_id 16 \\N 100396 Using index; Using filesort
- 1 SIMPLE f eq_ref PRIMARY PRIMARY 8 z3.i.feed_id 1
Handler_read_first + 1 : 从表t_feed_idx 中user_id索引开始位置进行读取
Handler_read_key + 11 : t_feed_idx 根据user_id读1次,t_feed_info根据feed_id读10次
Handler_read_rnd_next + 100001: filesort全表遍历读取表t_feed_idx 中user_id索引的100000行,进行排序; 额外的1是EOF标志位;
没有 Using temporary 是因为先对t_feed_idx的索引user_id进行排序,然后再join
Using filesort 原因:
无法使用t_feed_idx表的索引
1>先对表t_feed_idx排序,取10个feed_id
Handler_read_first + 1, Handler_read_key + 1, Handler_read_rnd_next + 100001
2>然后根据feed_id与表t_feed_info进行join
Handler_read_key + 10
参考: http://www.mysqlperformanceblog.com/2010/06/15/what-does-handler_read_rnd-mean/
MYSQL: Handler_read_%参数说明的更多相关文章
- MySql配置参数很全的Mysql配置参数说明
MySql配置参数 很全的Mysql配置参数说明 1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很 ...
- mysql CMAKE 参数说明
MySQL自5.5版本以后,就开始使用CMake编译工具了,因此,你在安装源文件中找不到configure文件是正常的.很多人下到了新版的MySQL,因为找不到configure文件,不知道该怎么继续 ...
- MySQL 启动参数说明及性能优化建议
[mysqld] port = 3306 serverid = 1 socket = /tmp/mysql.sock skip-name-resolve #禁止MySQL对外部连接进行DNS解析,使用 ...
- MySQL slave_exec_mode 参数说明
背景: 今天无意当中看到参数slave_exec_mode,从手册里的说明看出该参数和MySQL复制相关,是可以动态修改的变量,默认是STRICT模式(严格模式),可选值有IDEMPOTENT模式(幂 ...
- MySQL配置参数说明
MYSQL服务器my.cnf配置参数详解: 硬件:内存16G [client] port = 3306 socket = /data/mysql.sock [mysql] no-auto-rehash ...
- mysql 部分参数说明
log_timestamps [5.7] This variable was added in MySQL 5.7.2. Before 5.7.2, timestamps in log message ...
- MySQL常用参数说明(持续更新)
##innodb correlate innodb_flush_log_at_trx_commit value: 0,[1],2 effect: control the flush opera ...
- CentOS 7 安装 配置 MySQL
第一部分:CentOS 7安装MySQL 5.7 1.下载YUM库 shell > wget http://dev.mysql.com/get/mysql57-community-release ...
- MySQL 第一篇
一.MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司.MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数 ...
随机推荐
- Hive QL
转自http://www.alidata.org/archives/581 Hive 的官方文档中对查询语言有了很详细的描述,请参考:http://wiki.apache.org/hadoop/Hiv ...
- js中ajax如何解决跨域请求
js中ajax如何解决跨域请求,在讲这个问题之前先解释几个名词 1.跨域请求 所有的浏览器都是同源策略,这个策略能保证页面脚本资源和cookie安全 ,浏览器隔离了来自不同源的请求,防上跨域不安全的操 ...
- 性能测试-ApacheBench
基本简介 ApacheBench 是一个指令列程式,专门用来执行网站服务器的运行效能,特别是针对Apache 网站服务器.这原本是用来检测 Apache 网站服务器能够提供的效能,特别是可以看出Apa ...
- Yii 1 数据库操作 笔记
$result = array( 'id'=>null, 'val'=>0 ); $row1 = Yii::app()->db->createCommand()->ins ...
- 非对称认证方式 可以用在 asp.net webapi 的安全机制里面
//Client端调用 static void Main(string[] args) { string publicKey = "DpLMCOihcYI2i6DaMbso9Dzo1miy7 ...
- 通用数据链接(UDL)的用法
偶然看到UDL,决定看一下其用法. UDL:通用数据链接.此文件中提供 OleDbConnection 的连接信息.也就是说UDL只能在OleDbConnection中使用. 微软不建议使用UDL 因 ...
- DataGrid参数
1.3.2 data-options="singleSelect:true,collapsible:false,url:'/datagrid/getbasic'" 参数 类型 ...
- 第一百九十六天 how can I 坚持
老妈邮的咸菜到了,美味啊,买不到,哈哈. 以后要勤给鱼换水啊,10天不换,水都臭了,拒绝懒惰. 明天要回济南了,刘松结婚,估计又没法发博客了. 两条鱼,一条罗娜,一条我,哈哈. 睡觉.
- Gridheh 垂直居中
Gridheh 垂直居中 上下居中 each columns set layout ColumnDefValues.Layout = tlCenter 有colResize,拖动调整列宽. 但是没有 ...
- USB -- BULK_ONLY和UFI协议
2 BULK_ONLY和UFI协议 Bulk—Only协议是USB组织针对大容量存储设备制定的一种块存储类协议,目前已经普遍应用于各种移动存储设备. USB设备分为5大类,即显示器.通信设备.音频设备 ...