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》


  • 相关阅读:
    [Codechef Coders' Legacy 2018 CLSUMG]Sum of Primes
    [HDU4630]No Pain No Game
    [Luogu4329][COCI2006]Bond
    [数论]Gcd/ExGcd欧几里得学习笔记
    [数论]线性基学习笔记
    [Luogu5190][COCI2010]PROGRAM
    IIS7 HTTPS 绑定主机头,嘿嘿,转
    React
    ios
    iOS10 权限配置
  • 原文地址:https://www.cnblogs.com/coser/p/2237203.html
Copyright © 2011-2022 走看看