MySQL 8 引入索引 VISIBLE 与 INVISIBLE 的实战意义

发布时间: 2018-08-07 10:02:49 作者: 大象笔记

实际使用场景:

线上服务的数据库中某个字段已经创建了索引,但是后续运营过程中,发现这个索引并没有实际用途,反而影响了写入速度。那么,我们就会想去掉这个字段的索引。可是,在数据量非常大的情况下,新建索引,删除索引都是一件非常耗时的操作。所以,删除索引的操作,马虎不得。一旦发现这个索引还有其他业务用到,再重新建索引,耗时的创建过程会严重影响线上业务。

这时,index 的 visible 和 invisible 就非常实用了。可以先将该索引设置为 invisible,这样优化器就会忽略这个索引,但是索引依然存在于引擎内部。而设置 invisible 和 visible 操作的耗时又非常少,对业务基本没有任何影响。这样,观察一段时间后,如果业务一切正常,就可以删除索引了。

注意,索引 VISIBLE 与 INVISIBLE 在 MySQL 8 之后才支持

我开发环境用了 MySQL 8, 默认生成的建表语句中使用了默认的 VISIBLE index

例如:

CREATE TABLE `keywords` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(255) CHARACTER SET 'utf8mb4' COLLATE 'utf8mb4_bin' NULL,
  PRIMARY KEY (`id`),
  UNIQUE INDEX `ux_name` (`name` ASC) VISIBLE);

但是如果把这个建表语句发到线上服务器的 MySQL 5.7 上执行,则会报错

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'VISIBLE)' at line 5

所以,既然 index 默认为 visible,那建表语句中不写 visible 为好。

参考

http://mysql.taobao.org/monthly/2017/07/03/

我是一名山东烟台的开发者,联系作者