MySQL 8.0 新特性:Descending Indexes

文若2年前技术文章853


一、前言

MySQL 8.0 之前的索引排序规则之前只允许 ASC 存储,创建时指定 DESC 也会被忽略,

截屏2021-01-14 上午10.59.32.png

截屏2021-01-13 下午5.38.01.png

8.0 版本为我们带来了 Descending Indexes 降序索引 👏👏👏

只能使用 ASC 索引,带来的问题就是使用 DESC 会出现更多的 using filesort 导致更多的性能损耗

二、动手实验 5.7

  1. 5.7 版本用了一张推荐系统的表,简单测试一下:

explain select similarity from new_correlation group by similarity order by similarity asc ;

Snipaste_2021-01-13_17-57-29.png

此时我们是在 5.7 版本里创建了一个 idx_similarity_desc(similarity desc)  发现虽然创建的是倒序索引,但是没有效果,依然是按照 ASC 组织的。下面是使用 DESC 排序下 SQL 的执行计划:

explain select similarity from new_correlation group by similarity order by similarity desc \G

Snipaste_2021-01-13_18-04-51.png

此时是在 5.7 版本下使用倒序 DESC 我们从执行计划里发现比 ASC 多了 Using temporaryfilesort 使用临时表和文件排序,一般我们认为执行计划中有这两个的性能都不咋地,而且执行频率高的话系统 IO 的压力也会非常大,比如羽勒的内站系统数据库,配置只有 2C4G 有一个业务必须使用 DESC 排序,并发上来时 CPU 可以顶得住 IOPS 却已经到极限了。


那么到底是有多大区别呢?请继续往下看


我们使用 MySQL 执行监控计数器看看二者的区别~

下方是使用 ASC 时的计数器 Handler_read_key 较高说明查询及索引均使用正确。

Snipaste_2021-01-13_19-21-35.png

下面是使用 DESC 时计数器,发现多了很多计数 Handler_read_rnd_next 从数据节点读取到下一个数据节点的次数,说明索引使用不正常,消耗的资源也是比 ASC 大许多。

Snipaste_2021-01-13_19-22-21.png

我们可以看到 5.7 即使我们创建 DESC 索引但是依然是按照 ASC 排序的,某些情况下是比较消耗性能的。

Snipaste_2021-01-13_19-29-18.png

三、8.0 新特性改善

我们到 8.0 中重新运行刚才的 SQL 我们添加 DESC 索引

alter table new_correlation add index idx_similarity_desc(similarity desc);

Snipaste_2021-01-13_19-35-44.png

发现 Using temporaryfilesort 已经没有了,使用了 idx_similarity_desc 索引,统计信息如下👇 创建的倒序索引不再失效。

Snipaste_2021-01-13_19-37-39.png

后面我们可以根据业务情况创建合适组织顺序的索引,减少更多不必要的性能损耗。

相关文章

kubernetes调度和调度器

一、Kubernetes调度Scheduler 是 kubernetes 的调度器,主要的任务是把定义的 pod 分配到集群的节点上。听起来非常简单,但有很多要考虑的问题:公平:如何保证每个节点都能被...

ORA-00031报错处理

1、在数据库里面kill语句时会发生如下的报错:SQL> alter system kill session '4390,2679';alter system kill session '439...

MinIO文件服务

MinIO文件服务

MinIO官网地址:docs.min.io/cn/一、Minio简介Minio 是一个基于Apache License v2.0开源协议的对象存储服务。它兼容亚马逊S3云存储服务接口,非常适合于存储大...

数据库性能大揭秘:玩转MySQL监控指标状态变量

前言在本文中,我们将深入探讨MySQL数据库的性能监控世界。通过了解并应用一系列常用的监控指标,我们能够更精准地把握数据库的运行状况。这些指标,通常以状态变量(status variables)的形式...

ES运维(五)聚合分析流程及精准度

ES运维(五)聚合分析流程及精准度

1、 概述ES是一个近实时的搜索引擎,提供近实时海量数据的聚合分析功能,但这个海量数据聚合分析是会损失一定的精准度来满足实时性能需要的。 2、 分布式系统的近似统计算法如下图,在分布式数据分...

DDoS木马攻击处理

DDoS木马攻击处理

问题描述云安全中心提示安全告警如下:恶意脚本代码执行DDoS木马问题解决安全组方向封禁查看次访问地址205.185.119.110 地址为国外一地址,去下载恶意脚本,因此在服务器出入安全组方向做了封禁...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。