关于mysql:万答19MySQL可以禁用MyISAM引擎吗

3次阅读

共计 849 个字符,预计需要花费 3 分钟才能阅读完成。

  • GreatSQL 社区原创内容未经受权不得随便应用,转载请分割小编并注明起源。

MyISAM 的实用场景越来越少了。

随着 MySQL 8.0 的推出,零碎表曾经全面采纳 InnoDB 引擎,不再须要 MyISAM 引擎。另外,MGR 中也不反对 MyISAM 引擎。

因而,基本上能够思考全面禁止应用 MyISAM 引擎了,问题是,这可行吗?

答案是必定的,能够做到。

从 MySSQL 5.7.8 开始,新增一个选项 disabled_storage_engines,只须要设置下即可:

disabled_storage_engines = MyISAM

这就完满地实现禁用 MyISAM 的目标了。

另外,这么设置的话,是不会影响 MySQL 实例初始化的。即使是在 MySQL 5.7 版本中,零碎表要应用 MyISAM 引擎,也不会影响生成 MyISAM 引擎的零碎表。

disabled_storage_engines is disabled and has no effect if the server is started with any of these options: --bootstrap, --initialize, --initialize-insecure, --skip-grant-tables.

不过,设置该选项后可能会影响 mysql_upgrade 降级:

Setting disabled_storage_engines might cause an issue with mysql_upgrade. For details, see Section 4.4.7,“mysql_upgrade — Check and Upgrade MySQL Tables”.

执行 mysql_upgrade 进行降级时可能会报错:

mysql_upgrade: [ERROR] 3161: Storage engine MyISAM is disabled
(Table creation is disallowed).

这时候须要长期敞开该选项,期待降级实现后再从新启用即可。

Enjoy GreatSQL :)

本文由博客一文多发平台 OpenWrite 公布!

正文完
 0