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

需要创建索引的情况

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

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

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

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

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

不要创建索引的情况

  • 表记录太少

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

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

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

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

posted @   小贼的自由  阅读(495)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示