Mysql索引使用
摘要:MySQL索引通常会提高查询的效率,但不恰当的使用会为数据库的内存和性能带来影响。
1.不要在列上使用函数或者运算,因为会导致全表扫描。
select * from news where year(time)>2017
可以改造为select * from news where publish_time < ‘2017-01-01’
2.尽量避免使用!=或者not in 或者<>,会导致索引失效
3.尽量避免使用or来连接。
4.多个单列索引
MySQL只能使用一个索引,会从多个索引中选择一个,如果创建多个单列索引,只能使用其中的一个,推荐使用复合索引。
5.复合索引的最左前缀
复合索引遵守“最左前缀”原则,即在查询条件中使用了复合索引的第一个字段,索引才会被使用。因此,在复合索引中索引列的顺序至关重要。如果不是按照索引的最左列开始查找,则无法使用索引。
select * from news where news_month = 1
此时,无法使用 new_idex(news_year, news_month) 索引,因为遵守“最左前缀”原则,在查询条件中没有使用复合索引的第一个字段,索引是不会被使用的。
6.范围查询会导致复合索引的右边失效
查询中的某个列有范围查询,则其右边所有列都无法使用索引优化查找。
这个时候,我们应该避免采用范围查询,采用一些数据库结构来实现去掉范围查询。
7.索引不会包含有null值的列
列中包含null值将不会被包含在索引中。在数据库设计时,应该避免列使用null