Mysql创建索引的原则
- 选择唯一索引。通过唯一索引可以快速的定位某一条数据。
- 为经常作为查询语句中的字段建立索引。
- 为经常需要进行排序、分组、联合操作的字段建立索引。
- 不要对需要经常进行增删改的字段建立索引
- 选择区分度大的字段建立索引
- 选择数据量小的字段建立索引
- 最左前缀原则单个索引查询的数据很多,区分度不是很大时,考虑建立组合索引提高查询效率
- 尽量扩展索引,而不是新建索引
索引失效的情况
- or导致索引失效
- <>,not,in,not exist
- 没有使用组合索引中的第一个索引(最左前缀原则)
- 组合索引前导列区分度大,且查后导列的时候,前导列的分裂非常耗资源
- 如果索引列为字符串,一定要用引号,否则不使用索引
- 对索引列进行了运算(+,-,*,/,使用函数等)
- 隐式转换(数据类型转换)
- like查询"%_",百分号在前面
- 全表扫描比使用索引快时
- 使用concat或||连接查询条件字段
- 指定不使用索引
sql调优
- 使用索引,尽量避免索引失效的情况
- 减少表连接数,连接的表越多,性能越差。将连接拆分成若干个过程逐一执行,先执行可显著减少数据量的连接
- 小表驱动大表
- 如果不可避免,可考虑使用临时表或表变量存放中间结果
- 更新update时不要更新所有字段
- 万变不离其宗:减少IO次数