mysql五种索引类型---实操版本

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: mysql五种索引类型---实操版本

mysql索引

4.3 总结

一:背景

1.1 故事背景

最近学习了Mysql的索引,索引对于Mysql的高效运行是非常重要的,正确的使用索引可以大大的提高MySql的检索速度。通过索引可以大大的提升查询的速度。不过也会带来一些问题。比如会降低更新表的速度(因为不但要把保存数据还要保存一下索引),占用磁盘空间等问题。


1.2 什么是索引

索引是数据库中的一种数据结构,用于提高查询速度和效率。它在表的一个或多个列上建立索引结构,使得数据库可以快速定位和访问数据,而无需扫描整个数据集。


二:前期准备

2.1 创建一个一百万条数据的表

1.创建一个表,如果有测试的表也可以用(把主键id设置为自增)

2.如果给字段添加的值有中文 需要将字符集改为UTF-8的格式

3.保存存储过程,用来添加100w条数据(字段和数据可以自己修改)

delimiter $$ # 定义结束符
drop procedure if exists addTestData; # 存储过程名叫:addTestData
create procedure addTestData()
begin
declare number int;
set number = 1;
while number <= 1000000 #插入N条数据
do
insert into test(id,user_name,`password`,text) #需要添加值得字段
values(null,concat('姓名_',number),concat('密码:',number),concat('账号',number,'密码',number)); # 对应字段的值 
set number = number + 1;
end
while;
end $$

4.调用存储过程来添加100w条数据

call addTestData();

5.执行的过程中会比较慢,大家可以使用select语句 查看创建了多少条数据了

select count(id) from test

三:实操过程

3.1 主键索引 primary

mysql提前给我们创建好了,不需要我们自己创建主键索引。

主键索引(Primary Key Index):主键索引是一种用于唯一标识表中每一行数据的索引。它要求索引列的值是唯一的且不为空,每个表只能有一个主键索引。主键索引可以加速对表中数据的唯一标识和访问,以及支持表的引用完整性约束。


3.2 唯一索引 unique

唯一索引(Unique Index):唯一索引要求索引列的值是唯一的,不允许重复值存在。与主键索引不同,一个表可以有多个唯一索引。唯一索引可以加速对数据的唯一性检查,提高查询效率。


3.2.1 对应语句

查询语句:
SELECT * FROM test where user_name ='姓名_19'
创建索引语句:
create unique index username ON test(user_name)

3.2.2 执行效果:
3.3 普通索引

普通索引(Non-Unique Index):普通索引(也称为非唯一索引)是最基本的索引类型。它允许重复值存在,并且一个表可以有多个普通索引。普通索引可以加速对数据的搜索和过滤,提高查询性能。

3.3.1 对应语句

查询语句
SELECT * FROM test WHERE `password`='密码:55'
创建普通索引语句
create index password on test( password )

3.3.2 执行效果

3.2.2 未创建普通索引

观察下面的图片可以看出,如果我们不创建索引的话,查询密码为55的数据需要0.649s

3.2.3 创建普通索引

观察下面图片,我们发现,添加普通索引之后时间降到了0.104s3.4 全文索引 fulltext

全文索引(Full-Text Index):全文索引用于对文本数据进行搜索,例如文章、描述等。它基于词汇分析,可以快速找到包含关键词的文本数据。全文索引支持模糊匹配、词干化、同义词扩展等功能,用于实现高效的全文搜索。

3.4.1 对应语句

查询语句
SELECT * FROM test where text LIKE '%郝立琢'
创建全文索引语句
create fulltext index text on test(text);
创建全文索引后的查询语句
select * from test where match(text) against('郝立琢');

3.4.1 对应语句

查询语句
SELECT * FROM test where text LIKE '%郝立琢'
创建全文索引语句
create fulltext index text on test(text);
创建全文索引后的查询语句
select * from test where match(text) against('郝立琢');

3.4.2 执行效果3.5 组合索引

组合索引(Composite Index):组合索引是基于多个列创建的索引。它可以包含两个或更多列,并按照指定的列顺序建立索引。组合索引可以加速多列条件查询,并且可以节省存储空间。但需要注意,组合索引的创建和维护成本较高,且只有在查询中涉及到索引的前缀列时才能发挥作用。


3.5.1 对应语句

查询语句
SELECT * FROM `test` where user_name="姓名_10" AND `password`="密码:10"
创建索引
create index username、password on test (user_name, password)

3.5.2 执行效果四:总结&提升

4.1 如何选择索引

在选择索引时需要考虑以下几点:


选择经常被查询的列进行索引,这样可以最大程度地提高查询性能。

对于连接表的列,也应考虑创建索引,以加速表之间的关联操作。

避免过多索引,因为过多的索引会增加存储空间和写操作的开销,并增加索引维护的复杂性。

根据查询的类型选择合适的索引类型。例如,B树索引适用于范围查询和排序操作,哈希索引适用于等值查询,全文索引适用于文本搜索。

4.2 索引的好处

索引的作用是加快数据库查询的速度,特别是对于大型数据集和复杂查询来说,索引可以显著减少查询的执行时间。

通过索引,数据库可以直接定位到满足查询条件的数据,而不需要逐条遍历整个表。

4.3 总结

本文介绍了索引,并且给出了具体的例子,在开发过程中一定要学会并且用好索引,提高我们查询的速度。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
17天前
|
SQL 关系型数据库 MySQL
深入解析MySQL的EXPLAIN:指标详解与索引优化
MySQL 中的 `EXPLAIN` 语句用于分析和优化 SQL 查询,帮助你了解查询优化器的执行计划。本文详细介绍了 `EXPLAIN` 输出的各项指标,如 `id`、`select_type`、`table`、`type`、`key` 等,并提供了如何利用这些指标优化索引结构和 SQL 语句的具体方法。通过实战案例,展示了如何通过创建合适索引和调整查询语句来提升查询性能。
118 9
|
2天前
|
存储 关系型数据库 MySQL
MySQL中为什么要使用索引合并(Index Merge)?
通过这些内容的详细介绍和实际案例分析,希望能帮助您深入理解索引合并及其在MySQL中的
20 10
|
7天前
|
关系型数据库 MySQL Linux
MySQL版本升级(8.0.31->8.0.37)
本次升级将MySQL从8.0.31升级到8.0.37,采用就地升级方式。具体步骤包括:停止MySQL服务、备份数据目录、下载并解压新版本的RPM包,使用`yum update`命令更新已安装的MySQL组件,最后启动MySQL服务并验证版本。整个过程需确保所有相关RPM包一同升级,避免部分包遗漏导致的问题。官方文档提供了详细指导,确保升级顺利进行。
47 16
|
15天前
|
存储 Oracle 关系型数据库
索引在手,查询无忧:MySQL索引简介
MySQL 是一款广泛使用的关系型数据库管理系统,在2024年5月的DB-Engines排名中得分1084,仅次于Oracle。本文介绍MySQL索引的工作原理和类型,包括B+Tree、Hash、Full-text索引,以及主键、唯一、普通索引等,帮助开发者优化查询性能。索引类似于图书馆的分类系统,能快速定位数据行,极大提高检索效率。
48 8
|
21天前
|
缓存 关系型数据库 MySQL
MySQL 索引优化以及慢查询优化
通过本文的介绍,希望您能够深入理解MySQL索引优化和慢查询优化的方法,并在实际应用中灵活运用这些技术,提升数据库的整体性能。
22 7
|
20天前
|
缓存 关系型数据库 MySQL
MySQL 索引优化与慢查询优化:原理与实践
通过本文的介绍,希望您能够深入理解MySQL索引优化与慢查询优化的原理和实践方法,并在实际项目中灵活运用这些技术,提升数据库的整体性能。
51 5
|
21天前
|
存储 关系型数据库 MySQL
mysql怎么查询longblob类型数据的大小
通过本文的介绍,希望您能深入理解如何查询MySQL中 `LONG BLOB`类型数据的大小,并结合优化技术提升查询性能,以满足实际业务需求。
84 6
|
9天前
|
存储 关系型数据库 MySQL
【MYSQL】 ——索引(B树B+树)、设计栈
索引的特点,使用场景,操作,底层结构,B树B+树,MYSQL设计栈
|
12天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3
|
12天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
42 3