MySQL-索引:聚集索引、覆盖索引、组合索引、前缀索引、唯一索引

文章目录


MySQL-索引:聚集索引、覆盖索引、组合索引、唯一索引

1、聚集索引

在数据库中,聚集索引决定了表数据行的物理存储顺序。在InnoDB存储引擎中,每个表都有一个聚簇索引。

一个表只能有一个聚集索引,并且通常建议选择那些具有唯一性、访问频繁且高度排序的列作为聚集索引。

clike 复制代码
CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT, -- 假设这是主键
    username VARCHAR(50),
    email VARCHAR(255),
    created_at TIMESTAMP
);

在InnoDB存储引擎中,默认情况下id作为聚集索引 。这意味着表中的行是按id的升序物理存储的,并且每个叶子节点包含了完整的行数据(包括username, email, created_at)。当你执行如下查询时,可以直接利用聚集索引来快速定位到指定id的数据行

coffeescript 复制代码
SELECT * FROM users WHERE id = 123;

2、覆盖索引

覆盖索引是指在查询过程中,只需要通过索引就能获取到所有需要的数据,而不需要再回到表中去查找行记录,这样可以减少磁盘I/O,显著提高查询性能。

如果一个查询语句所涉及的所有字段都出现在某个索引中,那么这个索引就被称作覆盖索引。不仅包括查询列,还包括结果集中所需的其他列(如在SELECT列表中的列)。

对于上述users表,如果我们创建了一个包含所有查询列的复合索引

rust 复制代码
CREATE INDEX idx_username_email ON users (username, email);

执行查看sql:

haskell 复制代码
SELECT username, email FROM users WHERE username = 'tom';

这个查询可以完全使用索引 idx_username_email 来完成,因为索引包含了查询所需的所有列,无需回表获取其他列数据,这就是一个覆盖索引的例子。

3、组合索引

同样以上述的idx_username_email为例,它是一个基于username和email两个列创建的组合索引。当执行如下的查询时,由于遵循了最左前缀原则,可以有效利用该索引:

matlab 复制代码
-- 可以利用索引
SELECT * FROM users WHERE username = 'Bob' AND email LIKE '%example.com';

-- 不会利用索引(仅使用了索引的一部分)
SELECT * FROM users WHERE email LIKE '%example.com';

4、唯一索引

在users表中,id列已经是一个主键,自动带有唯一约束。如果还需要确保邮箱地址的唯一性,可以添加一个唯一索引:

sql 复制代码
ALTER TABLE users ADD UNIQUE INDEX idx_unique_email (email);
相关推荐
.Shu.1 小时前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【五、InnoDB 高阶机制与实战调优】
数据库·mysql
新法国菜3 小时前
MySql知识梳理之DDL语句
数据库·mysql
DarkAthena3 小时前
【GaussDB】全密态等值查询功能测试及全密态技术介绍
数据库·gaussdb
ShawnLeiLei4 小时前
2.3 Flink的核心概念解析
数据库·python·flink
石皮幼鸟4 小时前
数据完整性在所有场景下都很重要吗?
数据库·后端
大只鹅5 小时前
Centos7.9 Docker26容器化部署 MySql9.4 一主一从的同步复制部署
mysql·centos
叁沐6 小时前
MySQL 28 读写分离有哪些坑?
mysql
nightunderblackcat6 小时前
新手向:异步编程入门asyncio最佳实践
前端·数据库·python
DarkAthena6 小时前
【GaussDB】使用MySQL客户端连接到GaussDB的M-Compatibility数据库
数据库·mysql·gaussdb
livemetee7 小时前
Flink2.0学习笔记:使用HikariCP 自定义sink实现数据库连接池化
大数据·数据库·笔记·学习·flink