zoukankan      html  css  js  c++  java
  • Mysql表引擎的切换

    转换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;

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

  • 相关阅读:
    哪里错了
    任性
    【转】JVM 堆最大能调多大?
    【Android】PA4D_CH7 文件、保存状态和首选项
    【Android】PA4D_CH6 使用Internat资源
    Think In Java 多态学习
    【转】Myeclipse 查看Jar文件里面源码中文乱码 问题解决
    [转载]getBoundClientRect函数详解
    Kettle 环境变量设置
    SQL Server 2012 不支持创建连接服务器到 2000 版本,及其替代方案
  • 原文地址:https://www.cnblogs.com/mahuanpeng/p/7226146.html
Copyright © 2011-2022 走看看