索引优化-MySQL性能优化

一、什么是索引

关于索引,可以类比书的目录,我们通过目录可以快速找到某个标题对应的开始页码。索引作用也是类似,通过索引,我们可以快速定位到某条行记录或者距离该条行记录最近的一个位置,从而避免从表的第一条行记录全表扫描去找某一条记录。

当表的记录数不多的时候,比如说一个表就几十上百条行记录,全表扫描消耗的时间不算长,但是当表的行记录有几百万、几千万甚至上亿条,全表扫一次的时间就会很长了,这个时候索引的作用就体现出来了。

合理的使用索引,可以有效的提升我们的查询效率。

二、索引的分类

MySQL数据库的索引是由存储引擎层实现的,不同的存储引擎对同一种索引类型的实现方式可能是不一样的。我们这里主要讲InnoDB存储引擎支持的索引类型。

针对索引数据结构,InnoDB存储引擎支持以下几种常见的索引类型:

1、B+树索引

B+树索引是关系型数据库最常见的索引,B+树索引是由平衡二叉树演变而来,弥补了B树范围查询性能低的特点。B+树的叶子节点才存放数据信息,非叶子节点只存放关键字信息,并且非叶子节点的关键字是子树中最大或者最小的值,如果要查找行记录的所有列信息,必须到叶子节点。B+树的叶子节点之间通过双向链表组织起来,很适合范围查询。而B树的非叶子节点和叶子节点值均不同,非叶子节点同样也存储行记录中其他列的值。

2、全文索引

全文索引是一种特殊的索引,查找的是文本中的关键词,可以将存储于数据库中的整本书或者整篇文章中的任意内容找出来。

3、哈希索引

InnoDB存储引擎采用自适应哈希索引来查找存储元数据的系统表,即数据字典。该自适应哈希索引只支持等值查询,不支持范围查询,且该索引由InnoDB引擎自己控制,DBA无法干预,只能通过参数innodb_adaptive_hash_index来禁用或者启动。

从索引是否是主键,又可以分为聚集索引和非聚集索引。

4、聚集索引

聚集索引其实就是主键,也叫聚簇索引。

5、非聚集索引

非聚集索引也叫辅助索引,是除了主键之外的其他索引。

相关推荐
2301_7765087223 分钟前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
cxr82833 分钟前
PaperclipAI 组织关系与智能体协作指南
数据库·人工智能·架构·ai智能体·openclaw
@insist1231 小时前
数据库系统工程师-Armstrong 公理系统:函数依赖推理与候选码求解核心方法论(重点)
数据库·软考·软件设计师·软件水平考试
山峰哥2 小时前
查询优化案例:从慢查询到闪电般的查询速度
数据库·sql·性能优化·编辑器·深度优先
杨云龙UP2 小时前
Oracle ASM磁盘组空间分配与冗余理解
linux·运维·数据库·sql·oracle
weixin199701080162 小时前
唯品会商品详情页前端性能优化实战
前端·性能优化
qq_410194292 小时前
.net性能优化的步骤,前端、后端、数据库
性能优化·.net
微学AI2 小时前
一款数据库SQL防火墙:可以拦截99.99%,可以阻止恶意SQL
数据库·sql
2401_884563242 小时前
Python Lambda(匿名函数):简洁之道
jvm·数据库·python
庞轩px3 小时前
MinorGC的完整流程与复制算法深度解析
java·jvm·算法·性能优化