MySQL_8.一级索引,二级索引概述

1.一级索引

索引和数据存储在一起,都存储在同一个B+tree中的叶子节点。一般主键索引都是一级索引

2.二级索引

二级索引树的叶子节点存储的是主键而不是数据。也就是说,在找到索引后,得到对应的主键,再回到一级索引中找主键对应的数据记录。

3.一级索引和二级索引的关系:回表

一级索引可以单独存在,二级索引不能单独存在,必须依附于一级索引,这叫做"回表"。

4.二级索引优缺点

优点:

(1)减少数据冗余

(2)减少行移动或者数据页分裂时二级索引的维护工作,当数据需要更新的时候,二级索引不需要修改,只需要修改一级索引,

一个表只能有一个一级索引,其他的都是二级索引,这样只需要修改一级索引就可以了,不需要重新构建二级索引

缺点:

根据二级索引查找行的完整数据需要回表

5.创建二级索引

(1)创建二级索引:

复制代码
CREATE INDEX [index name] ON [table name]([column name]);

(2)或者

复制代码
ALTER TABLE [table name] ADD INDEX [index name]([column name]);

注:在MySQL中,CREATE INDEX 操作被映射为 ALTER TABLE ADD_INDEX。

6.例二级索引格式

例如创建如下一张表:

复制代码
CREATE TABLE users(
    id INT NOT NULL, 
    name VARCHAR(20) NOT NULL,
    age INT NOT NULL, 
    PRIMARY KEY(id) 
    );

新建一个以age字段的二级索引:

复制代码
ALTER TABLE users ADD INDEX index_age(age);

MySQL会分别创建主键id的聚簇索引和age的二级索引:

在MySQL中主键索引的叶子节点存的是整行数据,而二级索引叶子节点内容是主键的值。

7.二级索引的检索过程

在MySQL的查询过程中,SQL优化器会选择合适的索引进行检索,在使用二级索引的过程中,因为二级索引没有存储全部的数据,

假如二级索引满足查询需求(一般来说,比如只查id和当前列属性),则直接返回,即为覆盖索引,反之则需要回表去主键索引(聚簇索引)查询。

例如执行

复制代码
SELECT * FROM users WHERE age=35;

在MySQL中,创建一张表时会默认为主键创建聚簇索引,B+树将表中所有的数据组织起来,即数据就是索引主键所以在InnoDB里,

主键索引也被称为聚簇索引,索引的叶子节点存的是整行数据。而除了聚簇索引以外的所有索引都称为二级索引,二级索引的叶子节点内容是主键的值。

相关推荐
2401_8359568113 分钟前
Golang怎么写基准测试benchmark_Golang基准测试教程【完整】
jvm·数据库·python
阿杰学AI1 小时前
AI核心知识129—大语言模型之 向量数据库(简洁且通俗易懂版)
数据库·人工智能·ai·语言模型·自然语言处理·向量数据库·vector database
SPC的存折1 小时前
D在 Alpine 容器中手动搭建 Discuz 全攻略(包含镜像一键部署脚本,可直接用)
linux·数据库·mysql·缓存
李兆龙的博客1 小时前
从一到无穷大 #67 大查询根因分析 - 从 PinSQL 到 RCRank
数据库·时序数据库
AgCl231 小时前
MYSQL-6-函数与约束-3/17
android·数据库·mysql
junqiduhang1 小时前
Win11 MySQL 8.0 安装八步走
数据库·mysql
zhangchaoxies1 小时前
golang如何使用SQLx原生SQL查询_golang SQLx原生SQL查询使用方法
jvm·数据库·python
m0_743623921 小时前
mysql如何优化InnoDB缓冲池大小_mysql缓冲池内存调优
jvm·数据库·python
孟意昶2 小时前
Doris专题31-SQL手册-基础元素
大数据·数据库·数据仓库·分布式·sql·知识图谱·doris
m0_617881422 小时前
如何操作 XML 数据_XMLTYPE 与 EXTRACT 函数解析节点
jvm·数据库·python