登录
首页 >  数据库 >  MySQL

MySQL中修改数据表存储引擎的三种方法

来源:SegmentFault

时间:2023-01-22 20:55:56 205浏览 收藏

积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《MySQL中修改数据表存储引擎的三种方法》,就带大家讲解一下MySQL、SQLServer知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

第一种方法:ALTER TABLE

将表从一个引擎修改为另一个引擎最简单的办法是使用

mysql> ALTER TABLE mytable ENGINE = InnoDB;

上述方法适用任何的存储引擎,但执行时间较长。MySQL会按行将数据从原表复制到一张新表中,在复制过程中会消耗系统所有的I/O能力,同时会对原表加上读锁。如果在繁忙的表上执行此操作需要特别小心。

第二种方法:导出和导入数据

使用

mysql > CREATE TABLE innodb_table LIKE myisam_table;
mysql > ALTER TABLE innodb_table ENGINE=InnoDB;
mysql > INSERT INTO innodb_table SELECT * FROM myisam_table;

如果数据量大,可考虑分批处理,针对每一段数据执行事务提交操作,以免大事务产生过多的undo。

假设有主键字段id,可重复运行以下语句将数据导入新表:

mysql > START TRANSACTION;
mysql > INSERT INTO innodb_table SELECT * FROM myisam_table
        -> WHERE id BETWEEN x AND y;
mysql > COMMIT;

以上操作完成后,新表是原表的一个全量复制,原表不受任何影响。如果有必要,可以在执行中对原表加锁,确保新表与原表的数据一致。

persona Toolkit提供了一个pt-online-schema-change的工具,可以简单方便地执行上述的过程,避免手工操作可能导致的失误。

今天关于《MySQL中修改数据表存储引擎的三种方法》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>