mysql btree脚本_MySQL优化之BTree索引使用规则

MySQL优化之BTree索引使用规则

从一道题开始分析:

假设某个表有一个联合索引(c1,c2,c3,c4)以下那个只能使用该联合索引的c1,c2,c3部分

explain select * from t where c1='a1' and c2='a2' and c4='a4' and c3='a3';

explain select * from t where c1='a1' and c2='a2' and c4='a4' order by c3;

explain select * from t where c1='a1' and c2='a2' and c4='a4' order by c1;

explain select * from t where c1='a1' and c4='a4'group by c3,c2;

explain select * from t where c1='a1' and c4='a4'group by c2,c3;

explain select * from t where c1='a1' and c4='a4'order by c2,c3;

explain select * from t where c1='a1' and c5='a5' order by c2,c3;

创建表后插入数据:

insert into t

values

('a1','a2','a3','a4','a5'),

('b1','b2','b3','b4','b5');

添加索引:

alter table t add index c1234(c1,c2,c3,c4);

mysql> explain select * from t where c1='a1' and c2='a2' and c4='a4' and c3='a3’;(MySQL执行时会改变其中的位置,c3会在c4的前边)

+----+-------------+-------+------+---------------+-------+---------+-------------------------+------+-----------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref                     | rows | Extra                 |

+----+-------------+-------+------+---------------+-------+---------+-------------------------+------+-----------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 168     | const,const,const,const | 1    | Using index condition |

+----+-------------+-------+------+---------------+-------+---------+-------------------------+------+-----------------------+

1 行于数据集 (0.05 秒)

mysql> explain select * from t where c2='a1' and c3='a4’; (根据索引的左前缀规则,c2,c3部分没有索引)

+----+-------------+-------+------+---------------+------+---------+------+------+-------------+

| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra       |

+----+-------------+-------+------+---------------+------+---------+------+------+-------------+

| 1  | SIMPLE      | t     | ALL  | NULL          | NULL | NULL    | NULL | 4    | Using where |

+----+-------------+-------+------+---------------+------+---------+------+------+-------------+

1 行于数据集 (0.08 秒)

mysql> explain select * from t where c1='a1' and c2='a2' and c4='a4' order by c3;(根据索引的左前缀规则,order by部分没有索引)

+----+-------------+-------+------+---------------+-------+---------+-------------+------+------------------------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref         | rows | Extra                              |

+----+-------------+-------+------+---------------+-------+---------+-------------+------+------------------------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 84      | const,const | 1    | Using index condition; Using where |

+----+-------------+-------+------+---------------+-------+---------+-------------+------+------------------------------------+

1 行于数据集 (0.08 秒)

mysql> explain select * from t where c1='a1' and c2='a2' and c4='a4' order by c1;(根据索引的左前缀规则,order by使用了索引,可以存在where与order by同时使用索引的情况)

+----+-------------+-------+------+---------------+-------+---------+-------------+------+-----------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref         | rows | Extra                 |

+----+-------------+-------+------+---------------+-------+---------+-------------+------+-----------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 84      | const,const | 1    | Using index condition |

+----+-------------+-------+------+---------------+-------+---------+-------------+------+-----------------------+

1 行于数据集 (0.09 秒)

(以下四组对比,说明在group by 和order by 中,使用索引的顺序,可以避免使用临时表和filesort)

mysql> explain select * from t where c1='a1' and c4=‘a4' group by c3,c2;

+----+-------------+-------+------+---------------+-------+---------+-------+------+---------------------------------------------------------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref   | rows | Extra                                                               |

+----+-------------+-------+------+---------------+-------+---------+-------+------+---------------------------------------------------------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 42      | const | 1    | Using index condition; Using where; Using temporary; Using filesort |

+----+-------------+-------+------+---------------+-------+---------+-------+------+---------------------------------------------------------------------+

1 行于数据集 (0.09 秒)

mysql> explain select * from t where c1='a1' and c4='a4'group by c2,c3;

+----+-------------+-------+------+---------------+-------+---------+-------+------+------------------------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref   | rows | Extra                              |

+----+-------------+-------+------+---------------+-------+---------+-------+------+------------------------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 42      | const | 1    | Using index condition; Using where |

+----+-------------+-------+------+---------------+-------+---------+-------+------+------------------------------------+

1 行于数据集 (0.12 秒)

mysql> explain select * from t where c1='a1' and c4='a4'order by c2,c3;

+----+-------------+-------+------+---------------+-------+---------+-------+------+------------------------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref   | rows | Extra                              |

+----+-------------+-------+------+---------------+-------+---------+-------+------+------------------------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 42      | const | 1    | Using index condition; Using where |

+----+-------------+-------+------+---------------+-------+---------+-------+------+------------------------------------+

1 行于数据集 (0.13 秒)

mysql> explain select * from t where c1='a1' and c5='a5' order by c3,c2;(使用的c1索引)

+----+-------------+-------+------+---------------+-------+---------+-------+------+----------------------------------------------------+

| id | select_type | table | type | possible_keys | key   | key_len | ref   | rows | Extra                                              |

+----+-------------+-------+------+---------------+-------+---------+-------+------+----------------------------------------------------+

| 1  | SIMPLE      | t     | ref  | c1234         | c1234 | 42      | const | 1    | Using index condition; Using where; Using filesort |

+----+-------------+-------+------+---------------+-------+---------+-------+------+----------------------------------------------------+

1 行于数据集 (0.15 秒)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值