【MySQL】索引相关

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 面试官:我们简单聊一下mysql索引相关东西吧。不了解是吧,行,那我们今天面试先到这。感谢参加本次面试哈

MySQL系列文章


索引结构

首先要理解索引是什么,索引是一个特殊的数据结构简单理解成一本书的书签,当一张表建立索引时磁盘中也会存储一个独立的索引结构,通过建立的树状结构查询。这里为什么能加速查询也就显而易见了,树状查询比列表查询快很多。


索引存储在磁盘中的数据结构为B+树,本质上为一个多叉树,类似下图这样,仅有叶子节点存储数据。

image.png


索引逻辑结构类型


从逻辑结构上划分为聚簇索引非聚簇索引。

聚簇索引

  • 聚簇索引就是按照每张表的主键构造一颗B+树,同时叶子节点中存放的就是整张表的行记录数据。这个特性决定了索引组织表中数据也是索引的一部分,每张表只能拥有一个聚簇索引。
  1. 优点:数据访问更快,因为聚簇索引将索引和数据保存在同一个B+树中,因此从聚簇索引中获取数据比非聚簇索引更快,聚簇索引对于主键的排序查找和范围查找速度非常快
  2. 缺点:
  1. 插入速度严重依赖于插入顺序,按照主键的顺序插入是最快的方式,否则将会出现页分裂,严重影响性能。因此,对于InnoDB表,我们一般都会定义一个自增的ID列为主键
  2. 更新主键的代价很高,因为将会导致被更新的行移动。因此,对于InnoDB表,我们一般定义主键为不可更新。
  3. 二级索引(手动添加的索引)访问需要两次索引查找,第一次找到主键值,第二次根据主键值找到行数据。

非聚簇索引

  1. 在聚簇索引之上创建的索引称之为辅助索引,辅助索引访问数据总是需要二次查找
  2. 辅助索引叶子节点存储的不再是行的物理位置,而是主键值。
  3. 通过辅助索引首先找到的是主键值,再通过主键值找到数据行的数据页,再通过数据页中的Page Directory找到数据行。
  4. innodb采用聚簇索引,mysima采用非聚簇索引


索引功能类型


而从功能上划分为主键索引、唯一索引、普通索引、全文索引

主键索引

  1. 主键索引是一种特殊的唯一索引,不允许值重复或者值为空。

唯一索引

  1. 唯一索引与普通索引类似,不同的是创建唯一性索引的目的不是为了提高访问速度,而是为了避免数据出现重复。

普通索引

  1. MySQL 中最基本的索引类型,它没有任何限制,唯一任务就是加快系统对数据的访问速度。

全文索引

  1. 用来查找文本中的关键字



索引下推

  1. 本质上为了减少回表次数从而减少io操作
  2. 根据条件在普通索引树搜索时,先在普通索引树结果执行where过滤条件再回表执行查询

覆盖索引

  1. 普通的索引查询步骤为,先根据索引树定位到主键,再根据主键去聚簇索引树回表查询数据行信息
  2. 本质上是索引中包含了要查询的字段信息,所以不用额外的进行回表查询

索引选错

  1. 优化器会根据扫描行数、是否使用临时表、是否排序、是否需要回表等因素进行综合判断。
  2. mysql执行语句时并不能准确知道满足条件的条数,只能统计估算
  3. InnoDB默认会选择N个数据页,统计这些页面上的不同值,得到一个平均值,然后乘以这个索引的页面数,就得到了这个索引的基数
  4. 数据会持续更新的,索引统计信息也会变。当变更的数据行数超过1/M的时候,会自动触发重新做一次索引统计。
  5. MySQL 会在选择索引的时候进行优化,如果 MySQL 认为全表扫描比走索引+回表效率高, 那么他会选择全表扫描,如果认为走索引的效率高,那么肯定也是会走索引的
  6. 如何解决?
  1. foces index强制按照指定索引查询
  2. 修改语句




相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
15天前
|
存储 关系型数据库 MySQL
Mysql索引总结(1)
Mysql索引总结(1)
23 0
|
16天前
|
存储 关系型数据库 MySQL
MySQL 索引的10 个核心要点
MySQL 索引的10 个核心要点
20 0
|
16天前
|
SQL 关系型数据库 MySQL
MySQL8.0索引新特性
MySQL8.0索引新特性
17 0
|
1天前
|
存储 SQL 关系型数据库
完蛋!😱 我被MySQL索引失效包围了!
完蛋!😱 我被MySQL索引失效包围了!
|
1天前
|
SQL 存储 关系型数据库
MySQL的3种索引合并优化⭐️or到底能不能用索引?
MySQL的3种索引合并优化⭐️or到底能不能用索引?
|
1天前
|
SQL 存储 关系型数据库
MySQL索引及事务
MySQL索引及事务
11 2
|
2天前
|
存储 SQL 关系型数据库
MySQL索引,看这一篇就够了!
MySQL索引,看这一篇就够了!
|
2天前
|
Java 关系型数据库 MySQL
MySQL 索引事务
MySQL 索引事务
12 0
|
2天前
|
存储 SQL 关系型数据库
MySQL 底层数据结构 聚簇索引以及二级索引 Explain的使用
MySQL 底层数据结构 聚簇索引以及二级索引 Explain的使用
14 0
|
2天前
|
自然语言处理 关系型数据库 MySQL
一文明白MySQL索引的用法及好处
一文明白MySQL索引的用法及好处
11 0