索引优化-MySQL性能优化

一、什么是索引

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

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

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

二、索引的分类

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

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

1、B+树索引

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

2、全文索引

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

3、哈希索引

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

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

4、聚集索引

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

5、非聚集索引

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

相关推荐
Apple_羊先森1 分钟前
ORACLE数据库巡检SQL脚本--19、磁盘读次数最高的前5条SQL语句
数据库·sql·oracle
全栈前端老曹38 分钟前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
神梦流1 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
让学习成为一种生活方式1 小时前
trf v4.09.1 安装与使用--生信工具42-version2
数据库
啦啦啦_99991 小时前
Redis-5-doFormatAsync()方法
数据库·redis·c#
生产队队长1 小时前
Redis:Windows环境安装Redis,并将 Redis 进程注册为服务
数据库·redis·缓存
老邓计算机毕设1 小时前
SSM找学互助系统52568(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb 毕业设计
痴儿哈哈1 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
洛豳枭薰2 小时前
Innodb一次更新动作
mysql
Σίσυφος19002 小时前
PCL法向量估计 之 方向约束法向量(Orientation Guided Normal)
数据库