MySQL索引详解(优缺点,何时需要/不需要创建索引,索引及sql语句的优化)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 目录MySQL索引详解(优缺点,何时需要/不需要创建索引,索引及sql语句的优化)一、什么是索引?二、索引的作用?三、优点:四、缺点五、什么时候需要创建索引六、什么时候不需要创建索引七、索引的分类:八、索引和sql语句的优化1、前导模糊查询不能使用索引,2、Union、in、or可以命中索引,建议使用in3、负条件查询不能使用索引,可以优化为in查询,4、联合索引最左前缀原则,又叫最左侧查询,5、建立联合查询时,区分度最高的字段在最左边6、如果建立了(a,b)联合索引,就不必再单独建立a索引。7、存在非等号和等号混合判断条件时,在建索引时,要把等号条件的列前置

MySQL索引详解(优缺点,何时需要/不需要创建索引,索引及sql语句的优化)


一、什么是索引?

索引是对数据库表中的一列或多列值进行排序的一种结构,使用索引可以快速访问数据库表中的特定信息。


二、索引的作用?

索引相当于图书上的目录,可以根据目录上的页码快速找到所需的内容,提高性能(查询速度)


三、优点:

通过创建唯一性索引,可以保证数据库表中的每一行数据的唯一性。
可以加快数据的检索速度
可以加速表与表之间的连接
在使用分组和排序进行检索的时候,可以减少查询中分组和排序的时间


四、缺点

创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。
索引需要占用物理空间,数据量越大,占用空间越大
会降低表的增删改的效率,因为每次增删改索引,都需要进行动态维护


五、什么时候需要创建索引

 主键自动建立唯一索引
 频繁作为查询条件的字段应该创建索引
 查询中排序的字段创建索引将大大提高排序的速度(索引就是排序加快速查找
 查询中统计或者分组的字段;


六、什么时候不需要创建索引


频繁更新的字段不适合创建索引,因为每次更新不单单是更新记录,还会更新索引,保存索引文件

where条件里用不到的字段,不创建索引;

表记录太少,不需要创建索引;

经常增删改的表;

数据重复且分布平均的字段,因此为经常查询的和经常排序的字段建立索引。注意某些数据包含大量重复数据,因此他建立索引就没有太大的效果,例如性别字段,只有男女,不适合建立索引。


七、索引的分类:

普通索引:最基本的索引,它没有任何限制

唯一索引:索引列的值必须唯一,且不能为空,如果是组合索引,则列值的组合必须唯一。

主键索引:特殊的索引,唯一的标识一条记录,不能为空,一般用primary key来约束。

联合索引:在多个字段上建立索引,能够加速查询到速度


八、索引和sql语句的优化


1、前导模糊查询不能使用索引,


如name like ‘%静’


2、Union、in、or可以命中索引,建议使用in


3、负条件查询不能使用索引,可以优化为in查询,


其中负条件有!=、<>、not in、not exists、not like等


4、联合索引最左前缀原则,又叫最左侧查询,


如果在(a,b,c)三个字段上建立联合索引,那么它能够加快a|(a,b)|(a,b,c)三组的查询速度。


5、建立联合查询时,区分度最高的字段在最左边


6、如果建立了(a,b)联合索引,就不必再单独建立a索引。

同理,如果建立了(a,b,c)索引就不必再建立a,(a,b)索引

7、存在非等号和等号混合判断条件时,在建索引时,要把等号条件的列前置


8、范围列可以用到索引,但是范围列后面的列无法用到索引。

索引最多用于一个范围列,如果查询条件中有两个范围列则无法全用到索引。范围条件有:<、<=、>、>=、between等。


9、把计算放到业务层而不是数据库层。

在字段上计算不能命中索引,


10、强制类型转换会全表扫描,

如果phone字段是varcher类型,则下面的SQL不能命中索引。Select * fromuser where phone=13800001234


11、更新十分频繁、数据区分度不高的字段上不宜建立索引。

更新会变更B+树,更新频繁的字段建立索引会大大降低数据库性能。


“性别”这种区分度不太大的属性,建立索引是没有什么意义的,不能有效过滤数据,性能与全表扫描类似。


一般区分度在80%以上就可以建立索引。区分度可以使用count(distinct(列名))/count(*)来计算。


12、利用覆盖索引来进行查询操作,避免回表。

被查询的列,数据能从索引中取得,而不是通过定位符row-locator再到row上获取,即“被查询列要被所建的索引覆盖”,这能够加速度查询。


13、建立索引的列不能为null,使用not null约束及默认值


14、利用延迟关联或者子查询优化超多分页场景,

MySQL并不是跳过offset行,而是取offset+N行,然后放弃前offset行,返回N行,那当offset特别大的时候,效率非常低下,要么控制返回的总数,要么对超过特定阈值的页进行SQL改写。


15、业务上唯一特性的字段,即使是多个字段的组合,也必须建成唯一索引。


16、超过三个表最好不要用join,

需要join的字段,数据类型必须一致,多表关联查询时,保证被关联的字段需要有索引。


17、如果明确知道查询结果只要一条,limit 1能够提高效率,比如验证登录的时候。


18、Select语句务必指明字段名称


19、如果排序字段没有用到索引,就尽量少排序


20、尽量用union all 代替 union。

Union需要将集合合并后在进行唯一性过滤操作,这会涉及到排序,大量的cpu运算,加大资源消耗及延迟,当然,使用union all的前提条件是两个结果集没有重复数据。


21、使用合理的分页提高效率。


select id,name from product limit 866613, 20


使用上述SQL语句做分页的时候,可能有人会发现,随着表数据量的增加,直接使用limit分页查询会越来越慢。


优化的方法如下:


可以取前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。


比如此列中,上一页最大的id是866612。


SQL可以采用如下的写法:select id,name from product where id> 866612 limit 20。


34.jpg


如果大家觉得还不错,点赞,收藏,分享,一键三连支持我一下~

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
存储 关系型数据库 MySQL
Mysql索引总结(1)
Mysql索引总结(1)
|
1天前
|
SQL 关系型数据库 MySQL
不允许你不知道的 MySQL 优化实战(一)
不允许你不知道的 MySQL 优化实战(一)
|
1天前
|
SQL 关系型数据库 MySQL
MySQL8.0索引新特性
MySQL8.0索引新特性
|
1天前
|
存储 SQL 关系型数据库
MySQL 索引
MySQL 索引
|
2天前
|
存储 缓存 关系型数据库
掌握MySQL数据库这些优化技巧,事半功倍!
掌握MySQL数据库这些优化技巧,事半功倍!
|
2天前
|
缓存 关系型数据库 MySQL
MySQL数据库优化技巧:提升性能的关键策略
索引是提高查询效率的关键。根据查询频率和条件,创建合适的索引能够加快查询速度。但要注意,过多的索引可能会增加写操作的开销,因此需要权衡。
|
3天前
|
SQL Oracle 关系型数据库
下次老板问你MySQL如何优化时,你可以这样说,老板默默给你加工资
现在进入国企或者事业单位做技术的网友越来越多了,随着去O的力度越来越大,很多国企单位都开始从Oracle向MySQL转移,相对于Oracle而言,MySQL最大的问题就是性能,所以,这个时候,在公司如果能够处理好MySQL的性能瓶颈,那么你也就很容易从人群中脱颖而出,受到老板的青睐。
22 1
|
3天前
|
SQL 存储 关系型数据库
MySQL Cluster集群安装及使用
MySQL Cluster集群安装及使用
|
18天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
7天前
|
关系型数据库 MySQL 数据库
《MySQL 简易速速上手小册》第1章:MySQL 基础和安装(2024 最新版)
《MySQL 简易速速上手小册》第1章:MySQL 基础和安装(2024 最新版)
30 4