mysql什么时候不需要建立索引

  • WHERE 条件,GROUP BY,ORDER BY 里用不到的字段,索引的价值是快速定位,如果起不到定位的字段通常是不需要创建索引的,因为索引是会占用物理空间的。
  • 字段中存在大量重复数据,不需要创建索引,比如性别字段,只有男女,如果数据库表中,男女的记录分布均匀,那么无论搜索哪个值都可能得到一半的数据。在这些情况下,还不如不要索引,因为 MySQL 还有一个查询优化器,查询优化器发现某个值出现在表的数据行中的百分比很高的时候,它一般会忽略索引,进行全表扫描。
  • 表数据太少的时候,不需要创建索引;
  • 经常更新的字段不用创建索引,比如不要对电商项目的用户余额建立索引,因为索引字段频繁修改,由于要维护 B+Tree的有序性,那么就需要频繁的重建索引,这个过程是会影响数据库性能的。
相关推荐
钢铁男儿8 分钟前
Python 正则表达式(正则表达式和Python 语言)
python·mysql·正则表达式
Kan先生2 小时前
对象存储解决方案:MinIO 的架构与代码实战
数据库·python
超级迅猛龙2 小时前
保姆级Debezium抽取SQL Server同步kafka
数据库·hadoop·mysql·sqlserver·kafka·linq·cdc
杨过过儿2 小时前
【Task02】:四步构建简单rag(第一章3节)
android·java·数据库
····懂···3 小时前
攻克PostgreSQL专家认证
数据库·postgresql
每天都在想吃啥3 小时前
day31 SQLITE
数据库·sqlite
helloyaren3 小时前
Docker Desktop里搭建Mysql 9.4主从复制的保姆级教程
mysql·技术·主从复制
weixin_456588154 小时前
【java面试day16】mysql-覆盖索引
java·mysql·面试
舒一笑5 小时前
MySQL中模糊匹配like的一个坑
后端·mysql
m0_748254096 小时前
2025最新华为云国际版注册图文流程-不用绑定海外信用卡注册
服务器·数据库·华为云