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

    需要创建索引的情况

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

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

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

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

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

    不要创建索引的情况

    • 表记录太少

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

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

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

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

  • 相关阅读:
    rogue 源码 curses图形库实现的
    FreeBSD命令(抄至网络)
    没动力没精神
    加班无聊逛论坛
    2009年的FreeBSD命令(转载的)
    freebsd上源码安装cmake
    freeBSD中fetch下载工具使用
    Mac 安装HomeBrew 踩坑总结
    mybatis插入数据时,自动获取主键的自增id
    java 8对List的处理
  • 原文地址:https://www.cnblogs.com/chasemeng/p/13763764.html
Copyright © 2011-2022 走看看