首页 > 代码库 > Mysql表引擎的切换
Mysql表引擎的切换
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 12.0px "PingFang SC" }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "PingFang SC" }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "PingFang SC"; min-height: 17.0px }
span.Apple-tab-span { white-space: pre }</style>
转换MYSQL表的引擎
1.方法一:Alter table
将1个表的引擎修改为另一个引擎最简单的方法是使用Alter table语句。
下面的语句将myTable的引擎修改为InnoDB
mysql>ALTER TABLE mytable ENGINE = InnoDB;
上述语法适用于任何一个引擎,但是有以下的缺点:
A.执行时间上,将数据从原表复制一份到新表中,消耗系统的I/O能力
B.原表会加上读锁,繁忙表上要特别注意
C.将失去和原引擎相关的所有特性,如原表的外键
2.方法二:导出和导入
可以使用mysqldump工具将数据导出到文件,然后修改文件中的CREATE TABLE 语句的存储引擎选择,注意要修改表名,即使使用不同的引擎。
注意:mysql导出的sql语句默认会带有drop table,不注意这一点会造成数据的丢失
3.方法三: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;
新表是原表的全量复制。如果有必要,可以在执行过程中对原表加锁,保证新表和原表数据一致。
Mysql表引擎的切换
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。