选择唯一索引
唯一性索引的值是唯一的,可以更快的通过该索引来确定某条记录
作为查询条件的字段建立索引
某个字段用来做查询条件,那么该字段的查询速度会影响整个表的查询速度。因此,为该字段建立索引,可以提高整个表的查询速度
限制索引的数量
索引的数据并不是越多越好,每个索引需要占据大量的磁盘空间,索引越多,需要的齿盘空间就越大
修改表时,索引过多会使表的恒信速度变慢
尽量使用字段数据少的索引
若索引的字段数据量过长,会导致查询的数独变慢
如:对一个char(200)类型的字段进行全文检索需要的时间比char(20)类型需要的时间更多
排序,分组和联合字段简历索引
使用order by,group by,distinct和union等操作的字段进行排序操作会浪费很多时间。
若为起建立索引,可以有效的避免排序操作
尽量使用前缀索引
索引字段的值很长,最好使用直的前缀来索引
ru:text和blog类型的字段,进行全文检索会浪费时间。若只检索字段的部分若干个字符,可以提高检索数速度
删除不使用或很少用的索引
表中的数据被批次更新火数据的使用方式被改变后,原有的一些索引可能不在需要。应当定期清理这些索引
小表不创建索引(超过200数据的表,创建索引)
包含很多列且不需要搜索非空值时可以考虑不建立索引
被用来记录字段的字段创建索引
primary key 字段,系统自动创建主键的索引
unique key 字段,系统自动创建对应的索引
foreign key约束所定义的作为外建的字段
在查询中用来连接表的字段‘
用作为排序(order by的字段)的字段
创建索引必须考虑数据的操作方式,原则是内容变动少,经常被用于查询的字段创建索引,对于经常性变动的表而言,则需要谨慎创建需要的索引