MySql

MySql索引优化

一、索引分析

1、单表

(1)、建表SQL
(2)、案例

2、两表

(1)、建表SQL
(2)、案例

3、三表

(1)、建表SQL
(2)、案例

二、索引失效(应该避免)

1、建表SQL

2、案例(索引失效)
    (1)、全值匹配我最爱
    (2)、2.最佳左前缀法则:如果索引了多例,要遵守最左前缀法则。指的是查询从索引的最左前列开始并且不跳过索引中的列。
    (3)、不在索引列上做任何操作(计算、函数、(自动or手动)类型转换),会导致索引失效而转向全表扫描
    (4)、存储引擎不能使用索引中范围条件右边的列
    (5)、尽量使用覆盖索引(只访问索引的查询(索引列和查询列一致)),减少select*
    (6)、mysql在使用不等于(!=或者<>)的时候无法使用索引会导致全表扫描;
    (7)、is null,is not null 也无法使用索引;
    (8)、like以通配符开头('$abc...')mysql索引失效会变成全表扫描操作;
    问题:解决like'%字符串%'索引不被使用的方法??
     (9)、字符串不加单引号索引失效;
    (10)、少用or,用它连接时会索引失效
    (11)、小总结:

3、面试题讲解
    (1)、题目SQL;
    (2)、定值、范围还是排序,一般order by是给个范围;
    (3)、group by 基本上都需要进行排序,会有临时表产生;

三、一般性建议

(1)、 对于单键索引,尽量选择针对当前query过滤性更好的索引;
(2)、在选择组合索引的时候,当前Query中过滤性最好的字段在索引字段顺序中,位置越靠前越好。
(3)、在选择组合索引的时候,尽量选择可以能包含当前query中的where子句中更多字段的索引;
(4)、尽可能通过分析统计信息和调整query的写法来达到选择合适索引的目的;
文章目录
  1. 1. 一、索引分析
    1. 1.0.0.1. 1、单表
    2. 1.0.0.2. 2、两表
    3. 1.0.0.3. 3、三表
  • 2. 二、索引失效(应该避免)
  • 3. 三、一般性建议