[MySQL优化] 需要创建索引和不要创建索引的情况

需要创建索引的情况

  • 主键自动建立唯一索引;

  • 频繁作为查询条件的字段应该创建索引;

  • 查询中与其他表关联的字段,外键关系建立索引;

  • 查询中排序的字段,排序字段若通过索引去访问将大大提高排序速度;

  • 查询中统计或者分组的字段(因为分组前必排序);

不要创建索引的情况

  • 表记录太少

  • 经常增删改的表:提高了查询速度,同时会降低更新表的速度,如对表经I性能 INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存出具,还要保存一下索引文件;

    (频繁更新的字段不适合创建索引,因为每次更新不单单是更新了记录还会更新索引;)

  • WHERE条件里用不到的字段不创建索引;

  • 数据重复且分布平均的表字段,因此应该只为最经常查询和最经常排序的数据列建立索引;注意,如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果(比如国籍、性别,不重复率(不重复数目/总数)越接近1,那么效率就越高)。

原文地址:https://www.cnblogs.com/chasemeng/p/13763764.html