【MySQL进阶之路 | 高级篇】MySQL8.0索引新特性->降序索引与隐藏索引

1. 支持降序索引

降序索引以降序存储键值.虽然在语法上,从MySQL4版本已经支持降序索引的语法了,但实际上该DESC定义是被忽略的.知道MySQL8.x版本才开始真正支持降序索引.(仅限于InnoDB存储引擎).

MySQL在8.0版本前创建的仍然是升序索引,使用时进行反向扫描,大大降低了数据库的效率.在某些场景下,降序索引的意义重大(反向存储,正向扫描,效率高).例如,一个查询需要对多个列进行排序,且顺序要求不一致,那么使用降序索引将避免数据库使用额外的文件排序操作,从而提高性能.

sql 复制代码
CREATE TABLE demo5(
a INT,
b INT,
INDEX demo5_index(a ASC, b DESC)
)

show index from demo5;

2. 隐藏索引

在MySQL5.7以前,只能通过显式的方式删除索引.此时,如果发现删除的索引后出现错误,又只能通过显式创建索引的方式将删除的索引创建回来.如果数据表的数据量非常大的话,或者数据表本身很大,这种操作会消耗系统过多的资源,操作成本非常高.

从MySQL8.0开始支持隐藏索引.只需要将索引设置为隐藏索引,使查询优化器不再使用这个索引(即使使用force index强制使用索引,优化器也不会使用),确定索引设置为隐藏后系统不受任何响应,就可以彻底删除索引.这种通过将索引设置为隐藏索引,再删除索引的方式就是软删除.

同时,如果你想验证某个索引删除后的查询性能,也可以暂时隐藏该索引.

注意 : 主键不能设置为隐藏索引.当表中没有显式主键时,表中第一个唯一非空索引成为隐式主键,其也不能被设置为隐藏.

索引默认是可见的.可以通过visible,invisible关键字设置索引的可见性.

(1). 创建表时隐藏索引

sql 复制代码
CREATE TABLE demo6(
a INT,
b INT,
INDEX demo6_index(a) INVISIBLE
);

show INDEX FROM demo6;

(2). 建表后,添加隐藏索引

sql 复制代码
ALTER TABLE demo6 
ADD INDEX demo6_index_a(b) invisible;

注:

当索引隐藏后,它的内容仍然跟正常索引一样实时更新的.如果一个索引需要长期被隐藏,可以将其删除,因为索引的存在会影响插入更新删除的性能.

相关推荐
dyxal5 分钟前
Windows 内网环境离线安装 MySQL 完整指南
windows·mysql·adb
Leon-Ning Liu37 分钟前
【系列实验二】RAC 19C集群:CentOS 7.9 原地升级至 Oracle Linux 8.10 实战笔记
linux·数据库·oracle·centos
川石课堂软件测试1 小时前
使用loadrunner调用mysql API进行性能测试
服务器·数据库·python·selenium·mysql·单元测试·自动化
倔强的石头1061 小时前
从 Oracle 到 KingbaseES:破解迁移痛点,解锁信创时代数据库新可能
数据库·oracle·金仓数据库
零日失眠者2 小时前
【Oracle入门到删库跑路-08】核心技能:用户和权限管理
数据库·oracle
7哥♡ۣۖᝰꫛꫀꪝۣℋ2 小时前
Spring IoC&DI
java·开发语言·mysql
我科绝伦(Huanhuan Zhou)2 小时前
Oracle控制文件、SCN与检查点机制深度解析及数据库初始化原理
运维·数据库·oracle
尋有緣2 小时前
力扣1327-列出指定时间段内所有的下单产品
leetcode·oracle·数据库开发
cui_win2 小时前
MySQL max_connections连接数配置没生效,最终靠改这个参数解决
数据库·mysql
杨云龙UP3 小时前
从0到可落地:Oracle RMAN异地NFS备份标准脚本(多实例通用)
linux·运维·数据库·oracle