当前位置: 首页 > article >正文

【MYSQL】索引篇(一)

1.为什么要有索引

索引的本质是一种数据结构,她的作用其实就是更好更快的帮我们找到数据库中存储的数据,就好比一本书,你想要找到指定的内容,但是如果在没有目录的情况下,你只能一页页的进行寻找,这样效率太低了。索引就相当于目录,能够迅速定位到你想要查找的内容。

2.索引的优缺点

2.1优点

1.上面已经提到了一点,如果没有索引,在我们查找我们需要的数据时,我们需要一行一行的比对,每次比对都需要从磁盘中获取数据,进行IO操作,所以索引的最主要作用就是减少无效的IO操作,加快查找速率。

2.在对数据库进行事务操作时,有助于保持数据一致性。可能有点不好理解,

举个🌰,当我们在图书馆借书时,

如果我没有索引,只能一个一个的去翻书架,一个个的去比对(全表扫描),此时整个图书馆需要把锁上整个书架区域,不让其他人打扰到我寻找我想要找的书(表锁)(其他人在书架区域外进行借还书等操作不受影响)只有我找到了,其他人才能开始,效率特别低

而如果有索引,我可以精确定位这个存书的格子,只把她锁住(行锁),不让别人借走了,但其他人可以同时去借其他的书,支持了并发。

正是因为索引的存在,让锁更精准的作用于目标数据,进一步提升一致性保障的效率和可靠性

3.在实现数据的参考完整性方面,可以加速表和表之间的连接 。换句话说, 对于有依赖关系的子表和父表连接查询时, 可以提高查询速度。

4.在使用分组和排序子句进行数据查询时,可以显著减少查询中分组和排序 的时间 ,降低了CPU的消耗。

2.2缺点

1.前面也说过了,索引的本质就是一种数据结构,所以索引就是典型的用空间换时间。索引索引的缺点之一就是需要单独开辟空间来存储索引,增大了内存的消耗。

2.我们在对数据库中的数据进行修改时,同时也要对索引进行相应的修改,对他进行相应的维护,这样也加大了,间接的降低了数据的更新速度,也正因为这个,在对数据的查询不多,对数据修改多 的情况下不建议使用索引,这时候显得有点鸡肋了

http://www.lryc.cn/news/2395247.html

相关文章:

  • ISCC-2025-web-wp
  • 鸿蒙分辨率
  • @Docker Compose 部署 Pushgateway
  • 我们来学mysql -- 从库重启,是否同步主库数据
  • King3399(ubuntu文件系统)iic(i2c)功能测试
  • 德思特新闻 | 德思特与es:saar正式建立合作伙伴关系
  • 基于原生JavaScript前端和 Flask 后端的Todo 应用
  • 一些Dify聊天系统组件流程图架构图
  • jq处理日志数据
  • Matlab程序设计基础
  • MIT 6.S081 2020 Lab6 Copy-on-Write Fork for xv6 个人全流程
  • 第304个Vulnhub靶场演练攻略:digital world.local:FALL
  • Unity 模拟高度尺系统开发详解——实现拖动、范围限制、碰撞吸附与本地坐标轴选择
  • 万字详解RTR RTSP SDP RTCP
  • 云服务器如何自动更新系统并保持安全?
  • 训练中常见的运动强度分类
  • java 递归地复制文件夹及其所有子文件夹和文件
  • [paddle]paddle2onnx无法转换Paddle3.0.0的json格式paddle inference模型
  • React项目在ios和安卓端要做一个渐变色背景,用css不支持,可使用react-native-linear-gradient
  • 【数据分析】特征工程-特征选择
  • 第4节 Node.js NPM 使用介绍
  • RK3399 Android7.1增加应用安装白名单机制
  • uni-app 安卓消失的字符去哪里了?maxLength失效了!
  • #AI短视频制作完整教程
  • 嵌入式STM32学习——串口USART 2.0(printf重定义及串口发送)
  • 【大模型】情绪对话模型项目研发
  • Git 教程 | 如何将指定文件夹回滚到上一次或某次提交状态(命令详解)
  • 【PCI】PCI入门介绍(包含部分PCIe讲解)
  • Cloudera Manager 学习笔记
  • Deepin 23.10安装Docker