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);
相关推荐
四七伵7 分钟前
Spring Boot项目中varchar字段为什么不用NULL?告别空指针从建表开始
数据库·后端
Mr.456711 分钟前
JDK17+Druid+SpringBoot3+ShardingSphere5 多表分库分表完整实践(MySQL+PostgreSQL)
java·数据库·spring boot·mysql·postgresql
Elastic 中国社区官方博客16 分钟前
使用 ES|QL 变量控件将仪表板转变为调查工具
大数据·运维·服务器·数据库·elasticsearch·搜索引擎·全文检索
feng68_19 分钟前
Ansible还原数据库节点
linux·运维·数据库·ansible
乐hh22 分钟前
清理MySQL数据
数据库·mysql
EasyCVR26 分钟前
国标GB28181/RTSP/ONVIF/RTMP视频监控平台EasyCVR视频质量诊断花屏/蓝屏/画面模糊/冻结检测
网络·数据库·音视频
C^h29 分钟前
RTthread中的内存池理解
linux·数据库·c++·算法·嵌入式
fobwebs31 分钟前
wordpress 网站安装了Yoast SEO,并且做了内容的优化后,如果想重置Yoast SEO,并且删除所有的优化内容,应该如何操作?
数据库·yoast seo·重置yoast seo·清空yoast seo内容
路由侠内网穿透1 小时前
本地部署开源 LLM 应用观测与调试平台 Langfuse 并实现外部访问
运维·服务器·数据库·物联网·开源
SPC的存折1 小时前
1、Ansible之Ansible安装与入门
linux·数据库·ansible