zoukankan      html  css  js  c++  java
  • [MySQL优化] 需要创建索引和不要创建索引的情况

    需要创建索引的情况

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

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

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

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

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

    不要创建索引的情况

    • 表记录太少

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

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

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

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

  • 相关阅读:
    红黑树
    二叉搜索树
    散列表
    快速排序
    堆排序
    归并排序
    插入排序
    Shell脚本之:函数
    Shell脚本之:退出循环
    ACM刷题之路(四)2018暑假实验室集训——深广搜专题题解
  • 原文地址:https://www.cnblogs.com/chasemeng/p/13763764.html
Copyright © 2011-2022 走看看