索引优化-MySQL性能优化

一、什么是索引

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

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

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

二、索引的分类

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

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

1、B+树索引

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

2、全文索引

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

3、哈希索引

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

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

4、聚集索引

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

5、非聚集索引

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

相关推荐
秋氘渔22 分钟前
智演沙盘 —— 基于大模型的智能面试评估系统
python·mysql·django·drf
大猫和小黄34 分钟前
若依微服务全面适配PostgreSQL-OpenGauss数据库
数据库·微服务·postgresql·若依
老徐电商数据笔记41 分钟前
技术复盘第二篇:电商数据主题域划分企业级实践
大数据·数据库·数据仓库·零售·教育电商·技术面试
jfqqqqq42 分钟前
postgres查询、重设自增序列的起始值
数据库·sql·postgres·自增序列
1 小时前
TIDB——PD(placement Driver)
java·数据库·分布式·tidb·
计算机毕设指导61 小时前
基于微信小程序的鸟博士系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
DemonAvenger1 小时前
Redis与MySQL双剑合璧:缓存更新策略与数据一致性保障
数据库·redis·性能优化
断春风1 小时前
如何避免 MySQL 死锁?——从原理到实战的系统性解决方案
数据库·mysql
闲人编程1 小时前
基础设施即代码(IaC)工具比较:Pulumi vs Terraform
java·数据库·terraform·iac·codecapsule·pulumi
QQ_21696290961 小时前
Spring Boot大学生社团管理平台 【部署教程+可完整运行源码+数据库】
java·数据库·spring boot·微信小程序