MySQL 中的索引数量是否越多越好?

不是越多越好,我们要根据实际需要来增加索引。InnoDB 中每创建一个索引,就会多维护一个B+树结构。索引的目的是为我们带来查询效率上的提高。如果不是频繁使用的查询字段,没有必要创建索引。

增加索引带来的问题
  1. 需要的磁盘存储空间增大,增加了一个B+树结构
  2. 影响缓冲池的命中率,对表进行操作的时候,索引数据也会加载到内存中,索引数据占用了内存,表数据就会相应的变少了,缓冲池的命中率降低
  3. 增删改的效率会降低,在索引存在时,每个涉及索引的操作都需要对索引数据进行维护
  4. 索引的命中会带来不确定性,可能会命中了一个不是最优的索引

如果不能带来查询效率上的提高,创建索引就没有必要

创建索引的依据
  1. 需要作为查询条件频繁查询的字段,经常在 order by 、group by 、 distinct 后面的字段也可以建立索引
  2. 字段的值增加索引后可以大规模的加快查询效率,要使用高选择性的字段作为索引。类似性别字段,没必要创建索引
  3. 减少回表,如果经常性使用查询条件 field1=value1 去查询 field2,可以使用 field1,field2 创建联合索引
  4. 复合索引,多个字段一起查询,可以创建复合索引,提升查询效率
相关推荐
贰拾wan29 分钟前
Redis的持久化-RDB
java·数据库·redis·缓存
KellenKellenHao1 小时前
Redis数据库基础与持久化部署
数据库·redis·缓存·持久化
ChinaRainbowSea1 小时前
用户中心——比如:腾讯的QQ账号可以登录到很多应用当中 02
java·服务器·spring boot·后端·mysql·mybatis
秋秋棠3 小时前
MyBatis动态SQL全解析:五大核心标签实战指南
数据库·sql·mybatis
西京刀客3 小时前
软删除设计:为什么使用 deleted_at = ‘1970-01-01 00:00:00‘ 表示未删除?
数据库·1970-01-01·软删除·deleted_at
wjpwjpwjp08314 小时前
[MySQL基础3] 数据控制语言DCL和MySQL中的常用函数
数据库·笔记·后端·学习·mysql
dustcell.4 小时前
数据库第二次作业
数据库
midsummer_woo5 小时前
基于springboot+vue+mysql的作业管理系统(源码+论文)
vue.js·spring boot·mysql
小云数据库服务专线5 小时前
GaussDB 数据库架构师修炼(三) 集群管理概览
数据库·数据库架构·gaussdb
爬山算法6 小时前
MySQL(144)如何处理日期和时间问题?
数据库·mysql