MYSQL索引创建时机和不适用的时机

👏作者简介:大家好,我是小周同志,25届双非校招生Java选手,很高兴认识大家

📕学习出处:本文是学自小林coding (xiaolincoding.com) 网站的MYSQL图解篇

🔥如果感觉博主的文章还不错的话,请👍三连支持👍一下博主哦

什么时候需要 / 不需要创建索引?

索引的优点:

  • 大大提高的查询速率。尤其是b+树,时间复杂度为O(logdN),当d就是最大节点为100时,应付千万级数据的查询,也只需要3-4次io操作。

索引的缺点:

  • 占用物理磁盘空间。

  • **索引需要维护。**比如修改这个索引的时候,索引内部会进行自适应排序。

  • 降低表的增删改的效率。因为每次增删改索引,B+ 树为了维护索引有序性,都需要进行动态维护

什么时候适用索引?
  • 字段有唯一性限制的

  • **经常用于where查询条件的字段。**可以增加查询的效率,当有多个字段查询条件时,可以使用联合索引。

  • **用于 GROUP BYORDER BY 的字段。**这样在查询的时候就不需要再去做一次排序了,因为建立索引之后在 B+Tree 中的记录都是排序好的。

什么时候不适用索引?
  • **没有用 whereGROUP BYORDER BY的。**既然 无法做到快速定位,那么就相当于索引没直到应有的作用,就不需要索引了,反而浪费了物理磁盘空间。

  • 存在大量重复数据的列不需要索引。 因为大量重复数据的话,索引就会进行多次磁盘和内存的io操作,性能消耗贼大,如果这样的话,还不如不加索引。MYSQL有个查询优化器,发现某个数据在表中出现的百分比比较大,会忽略索引,进行全表扫描。

  • **表数据太少,也不需要创建索引。**不需要索引也可以很快的找到数据,那么索引就没必要加了。

  • **经常更新的字段不需要创建索引。**索引字段被更新之后,b+树会进行自适应重排序,会影响数据库的性能。

相关推荐
三品吉他手会点灯2 分钟前
STM32F103学习笔记-19-SysTick-系统定时器(第1节)-功能框图讲解和优先级配置
笔记·stm32·单片机·嵌入式硬件·学习
لا معنى له4 分钟前
学习笔记:Transformer
人工智能·笔记·深度学习·学习·机器学习·transformer
JosieBook7 分钟前
【Vue】03 Vue技术——Vue.js 入门学习笔记:Hello World 案例详解
vue.js·笔记·学习
我想我不够好。18 分钟前
电工作业中元件的作用
学习
协同生态1 小时前
天锐绿盾新版注册机【仅用于个人学习,禁止其他用途】
学习
Cuby!1 小时前
【AFDM与信号处理:论文阅读】仿射频分复用:扩展OFDM以实现场景灵活性和弹性
论文阅读·笔记·学习·信息与通信·信号处理
AAA阿giao1 小时前
从零开始学 React:用搭积木的方式构建你的第一个网页!
前端·javascript·学习·react.js·前端框架·vite·jsx
Arciab1 小时前
C++ 学习_流程控制
c++·学习
HyperAI超神经1 小时前
【vLLM 学习】vLLM TPU 分析
开发语言·人工智能·python·学习·大语言模型·vllm·gpu编程
xiaoxiaoxiaolll2 小时前
前沿速递 | Adv. Eng. Mater.:基于LPBF与压力渗透的FeSi2.9-Bakelite多功能复合材料设计与性能调控
学习