zoukankan      html  css  js  c++  java
  • MySQL 联合索引测试2

    接上一篇文章:

    http://www.cnblogs.com/xiaoit/p/4430300.html

    1:首先删掉上一篇建立的索引,重新建立一个。

    mysql> DROP INDEX idx1 ON tab_index;
    Query OK, 55 rows affected (0.01 sec)
    Records: 55  Duplicates: 0  Warnings: 0
    

      

    mysql> ALTER TABLE tab_index
        -> ADD INDEX idx2(age,dte);
    Query OK, 55 rows affected (0.01 sec)
    Records: 55  Duplicates: 0  Warnings: 0
    

      

    按照上一篇的测试结论应该是:

    (age) 走索引,且索引长度最短
    (age,id)走索引,且索引长度最短

    (age,dte)走索引,且索引长度最长
    (id,age,dte)走索引,且索引长度最长
    (id,dte,age)走索引,且索引长度最长
    (dte,id,age)走索引,且索引长度最长
    (dte,age,id)走索引,且索引长度最长
    (age,dte,id)走索引,且索引长度最长
    (age,id,dte)走索引,且索引长度最长

    重新测试看下:

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE age=31;
    +----+-------------+-----------+------+---------------+------+---------+-------+------+-------------+
    | id | select_type | table     | type | possible_keys | key  | key_len | ref   | rows | Extra       |
    +----+-------------+-----------+------+---------------+------+---------+-------+------+-------------+
    |  1 | SIMPLE      | tab_index | ref  | idx2          | idx2 | 5       | const |    1 | Using where |
    +----+-------------+-----------+------+---------------+------+---------+-------+------+-------------+
    1 row in set (0.01 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE age=31 AND id=3;
    +----+-------------+-----------+------+---------------+------+---------+-------+------+-------------+
    | id | select_type | table     | type | possible_keys | key  | key_len | ref   | rows | Extra       |
    +----+-------------+-----------+------+---------------+------+---------+-------+------+-------------+
    |  1 | SIMPLE      | tab_index | ref  | idx2          | idx2 | 5       | const |    1 | Using where |
    +----+-------------+-----------+------+---------------+------+---------+-------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE age=31 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' ;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE id=3 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' AND age=31;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE id=3 AND age=31 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00';
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' AND id=3  AND age=31;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' AND age=31 AND id=3;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE id=3 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' AND age=31;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE id=3 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' AND age=31;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE age=31 AND id=3 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00'  ;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    mysql> EXPLAIN SELECT id,dte,age
        -> FROM tab_index
        -> WHERE age=31 AND dte BETWEEN '2011-05-13 00:00:00' AND '2013-05-13 00:00:00' AND id=3 ;
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    | id | select_type | table     | type  | possible_keys | key  | key_len | ref  | rows | Extra       |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    |  1 | SIMPLE      | tab_index | range | idx2          | idx2 | 14      | NULL |    1 | Using where |
    +----+-------------+-----------+-------+---------------+------+---------+------+------+-------------+
    1 row in set (0.00 sec)
    

      

    结论正确!

  • 相关阅读:
    CSS命名规范
    mysql对GIS空间数据的支持,包括创建空间索引
    jQuery和DOM对象
    教你轻松快速学会用Calibre TXT转MOBI
    教你如何写出一手漂亮的英文 ( 附视频教程 )
    推荐几个知名顶级的文献网站
    最常犯的12个逻辑错误
    信息学竞赛书籍
    适合入门的英语原版书
    2017十大流行编程挑战网站
  • 原文地址:https://www.cnblogs.com/xiaoit/p/4430387.html
Copyright © 2011-2022 走看看