环境:

表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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 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';

> WHERE + 排序
    # 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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 1    SIMPLE    i    ref    user_id    user_id    8    const    200    Using where; Using index
  3. 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

    # desc
    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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 1    SIMPLE    i    ref    user_id    user_id    8    const    200    Using where; Using index
  3. 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列进行排序

    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 f.feed_id LIMIT 0, 10;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 1    SIMPLE    i    ref    user_id    user_id    8    const    200    Using index; Using temporary; Using filesort
  3. 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中

    EXPLAIN SELECT * FROM `t_feed_idx` AS i
    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;

点击(此处)折叠或打开

  1. id    select_type    table    type    possible_keys    key    key_len    ref    rows    Extra
  2. 1    SIMPLE    i    index    \\N    user_id    16    \\N    100396    Using index; Using filesort
  3. 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_%参数说明的更多相关文章

  1. MySql配置参数很全的Mysql配置参数说明

    MySql配置参数 很全的Mysql配置参数说明 1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很 ...

  2. mysql CMAKE 参数说明

    MySQL自5.5版本以后,就开始使用CMake编译工具了,因此,你在安装源文件中找不到configure文件是正常的.很多人下到了新版的MySQL,因为找不到configure文件,不知道该怎么继续 ...

  3. MySQL 启动参数说明及性能优化建议

    [mysqld] port = 3306 serverid = 1 socket = /tmp/mysql.sock skip-name-resolve #禁止MySQL对外部连接进行DNS解析,使用 ...

  4. MySQL slave_exec_mode 参数说明

    背景: 今天无意当中看到参数slave_exec_mode,从手册里的说明看出该参数和MySQL复制相关,是可以动态修改的变量,默认是STRICT模式(严格模式),可选值有IDEMPOTENT模式(幂 ...

  5. MySQL配置参数说明

    MYSQL服务器my.cnf配置参数详解: 硬件:内存16G [client] port = 3306 socket = /data/mysql.sock [mysql] no-auto-rehash ...

  6. mysql 部分参数说明

    log_timestamps [5.7] This variable was added in MySQL 5.7.2. Before 5.7.2, timestamps in log message ...

  7. MySQL常用参数说明(持续更新)

      ##innodb correlate   innodb_flush_log_at_trx_commit value: 0,[1],2 effect: control the flush opera ...

  8. CentOS 7 安装 配置 MySQL

    第一部分:CentOS 7安装MySQL 5.7 1.下载YUM库 shell > wget http://dev.mysql.com/get/mysql57-community-release ...

  9. MySQL 第一篇

    一.MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司.MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数 ...

随机推荐

  1. Sublime Text 3快捷键

    Ctrl+Shift+P:打开命令面板 Ctrl+P:搜索项目中的文件 Ctrl+G:跳转到第几行 Ctrl+W:关闭当前打开文件 Ctrl+Shift+W:关闭所有打开文件 Ctrl+Shift+V ...

  2. PHP 碎片

    1. $_SERVER['REMOTE_ADDR'] cannot be modified by the user or via HTTP so you CAN trust it. -- 用这个可以有 ...

  3. windows程序移植linux

    1,路径名统一用正斜杠“/”.(windows下正反斜杠都识别,linux只认正斜杠.) 2,统一使用UTF-8格式编码. vim中无法保存汉字时,可输入下列命令: :set fileencoding ...

  4. 前端复习-03-接上面ajax跨域问题的解决与探索

    废话不多少 ..我估计一万个人都搞不清楚 什么是跨域 然后就被这堵墙无情的挡住了..我尝试了很多办法解决这个问题.后来再慕课网上的一个老师的ppt那里看到一张图 我觉得 能记住这张图的话 应该就算是深 ...

  5. 第二百三十四天 how can I 坚持

    今天果然不负众望,下了一天的雪啊,挺好. 今天把花搞了下,都弄花盆里了,希望不会就这么挂掉.八千代,绿萝,还有小叶元宝. 中午喝了点酒,没感觉. 过两天气温就零下十多度了,该咋办啊,最怕冬天.家里现在 ...

  6. cocos2dx移植android平台-我的血泪史

    版权声明:本文由( 小塔 )原创,转载请保留文章出处! 本文链接:http://www.zaojiahua.com/android-platform.html 本人这几天一直都没有跟新自己的网站内容, ...

  7. 【转】jsp页面中jstl标签详解

    原文地址: JSLT标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实 ...

  8. Java模板引擎 FreeMarker

    @(编程) [TOC] 1. 简介 FreeMarker是一个模板引擎,一个基于模板生成文本输出的通用工具,使用纯Java编写.它是为Java程序员提供的一个开发包.它不是面向最终用户的,而是为程序员 ...

  9. labview在线帮助网址

    http://zone.ni.com/reference/zhs-XX/help/371361L-0118/ labview网络讲坛 网址 http://v.eepw.com.cn/video/com ...

  10. 将nginx配置为服务,php-fpm配置说明

    编写shell脚本 vi /etc/init.d/nginx #!/bin/bash # # Startup script for the PHP-FPM server. # # chkconfig: ...