当前位置:   article > 正文

mysql怎么换引擎_mysql怎么切换引擎

mysql怎么换引擎_mysql怎么切换引擎

8bd5dd42318fb4a69e888bbdc707767a.png

切换引擎有以下三种方法:

方法一:Alter table

将1个表的引擎修改为另一个引擎最简单的方法是使用Alter table语句。

下面的语句将myTable的引擎修改为InnoDBmysql>ALTER TABLE mytable ENGINE = InnoDB;

上述语法适用于任何一个引擎,但是有以下的缺点:

A.执行时间上,将数据从原表复制一份到新表中,消耗系统的I/O能力

B.原表会加上读锁,繁忙表上要特别注意

C.将失去和原引擎相关的所有特性,如原表的外键

方法二:导出和导入

可以使用mysqldump工具将数据导出到文件,然后修改文件中的CREATE TABLE 语句的存储引擎选择,注意要修改表名,即使使用不同的引擎。

注意:mysql导出的sql语句默认会带有drop table,不注意这一点会造成数据的丢失

方法三:CREATE AND SELECT

结合第一种方法的高效和第二种方法的安全。不需要导出整个表的数据,只需要先创建一个新的存储引擎的表,然后利用INSERT....SELECT语法来导数据mysql >CREATE TABLE innodb_table LIKE myisam_table;

mysql >ALTER TABLE innodb_table Engine=InnoDB;

mysql >INSERT INTO innodb_table SELECT * From myisam_table;

如果数据量很大,可以考虑分批处理mysql> STSRT TRANSACTION

mysql> INSERT INTO innodb_table SELECT * From myisam_table where id BETWEEN x and y;

mysql> COMMIT;

新表是原表的全量复制。如果有必要,可以在执行过程中对原表加锁,保证新表和原表数据一致。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/595478
推荐阅读
相关标签
  

闽ICP备14008679号