zoukankan      html  css  js  c++  java
  • Mysql不同存储引擎的表转换方法

    Mysql不同存储引擎的表转换方法

    1、Alter table
    直接修改表的存储引擎,但是这样会导致大量的系统开销,Mysql为此要执行一个就表向新表的逐行复制。在此期间,转换操作可能会占用服务器的所有I/O处理能力。转换表之后,原先引擎的特殊性质都会丢失,无法复原。
    2、转储和导入方法
    用提供的mysqldump工具,可以将原有的表转换为一个文本文件,然后修改该文件,将里面的create table语句的引擎选项修改为需要更改后的引擎。
    3、创建一个新的表,并把旧表中的数据导入新的表

      create table innodb_table like myisam_table ; 
      alter table innodb_table engine=innodb;
      insert into innodb_table select * from myisam_table;
      drop myisam_table;
    

        以上方法适合数据量不大的情况,如果数据量很大的话,可能会产生大量的 undo log 日志,为了避免undo log过于庞大,可以逐段进行复制;

      start transaction;
      insert into innodb_table select * from myisam_table where id between x and y; #逐次增大x和y的值
      commit; 
    

      

    参考书籍:《高性能mysql》


  • 相关阅读:
    高精度乘除运算优化
    高精度除法
    高精度乘法
    期末考试
    P2341 [HAOI2006]受欢迎的牛[SCC缩点]
    P2002 消息扩散[SCC缩点]
    神奇搜索算法A*
    P3205 [HNOI2010]合唱队[区间dp]
    P4170 [CQOI2007]涂色
    P1220 关路灯[区间dp]
  • 原文地址:https://www.cnblogs.com/coser/p/2237203.html
Copyright © 2011-2022 走看看