批量转换MySQL数据库表的存储引擎的方法

21 篇文章 0 订阅


mysql_convert_table_format工具可以批量转换MYSQL数据库表的存储引擎,如果是RPM安装一般在/usr/bin 或者/usr/sbin下。本文我们主要介绍利用mysql_convert_table_format工具将MySQL数据库表的存储引擎批量转换为MYISAM引擎的方法,接下来就让我们来一起了解这一部分内容。

首先执行下面的代码:

   
   
  1. [root@test ~]# mysql_convert_table_format  
  2.  
  3. /usr/sbin/mysql_convert_table_format version 1.1  
  4.  
  5. Conversion of a MySQL tables to other table types. 

转换MYSQL表成其它表的类型,如:INNODB ,MEMORY等。

Usage: /usr/sbin/mysql_convert_table_format database [tables]。

用法: /usr/sbin/mysql_convert_table_format 数据库名 表名,也就是可以单独指定全库,或者全表,类似mysqldump。

If no tables has been specifed, all tables in the database will be converted。

如果没指定表,那么数据库中的所有表将会被转换。

   
   
  1. The following options are available:  
  2.  
  3. --force  
  4.  
  5. Continue even if there is some error. 

如果碰到错误强制进行转换。

   
   
  1. --help or --Information  
  2.  
  3. Shows this help 

查看帮助。

   
   
  1. --host='host name' (Default localhost)  
  2.  
  3. Host name where the database server is located. 

转换的主机名,默认为本地主机(localhost)。

   
   
  1. --password='password' 
  2.  
  3. Password for the current user. 

当前进行转换用户的密码。

   
   
  1. --port=port  
  2.  
  3. TCP/IP port to connect to if host is not "localhost". 

如果不是以localhost 连接的话,请指定端口。

   
   
  1. --socket='/path/to/socket' 
  2.  
  3. Socket to connect with. 

SOCKET文件存在的位置(SOCKET是进程间通信所用到的)。

   
   
  1. --ENGINE='table-type' 
  2.  
  3. Converts tables to the given table type (Default: myisam)  
  4.  
  5. MySQL 3.23 supports at least the BDB, ISAM and MYISAM types. 

存储引擎,默认为MYISAM,这里要注意,我测试的时候,要修改这个PERL脚本,如果你把库转成INNODB,就在脚本里把MYISAM写成INNODB。

   
   
  1. --user='user_name' 
  2.  
  3. User name to log into the SQL server. 

连接的用户名。

   
   
  1. --verbose  
  2.  
  3. This is a test specific option that is only used when debugging a test.  
  4.  
  5. Print more information about what is going on.  
  6.  
  7. --version  
  8.  
  9. Shows the version of this program. 

查看工具的版本信息。

用法:我是用本机进行测试,OS:RHEL5.2 MYSQL:5.1.30

mysql_convert_table_format mo --user='root' --password='mysql' --force --socket='/tmp/mysql.sock'

把数据库mo中的所有表转换成MYISAM引擎。

查看数据文件目录。

   
   
  1. [root@test ~]# ll /opt/mysql-data/mo/  
  2.  
  3. 总计 960  
  4.  
  5. -rw-rw---- 1 mysql mysql 12914 03-02 22:55 action_log.frm  
  6.  
  7. -rw-rw---- 1 mysql mysql 8900 03-02 22:55 alarm_log.frm  
  8.  
  9. -rw-rw---- 1 mysql mysql 8898 03-02 22:55 check_data.frm  
  10.  
  11. -rw-rw---- 1 mysql mysql 8836 03-02 22:55 check_data_log.frm  
  12.  
  13. -rw-rw---- 1 mysql mysql 1708 03-02 22:55 check_data_log.par  
  14.  
  15. -rw-rw---- 1 mysql mysql 8898 03-02 22:55 check_data_tmp.frm  
  16.  
  17. -rw-rw---- 1 mysql mysql 9096 03-02 22:55 checkpoint.frm  
  18.  
  19. ……………………………………. 

只有表的结构文件,看看表空间有没有增长。

   
   
  1. [root@test ~]# ll -lh /opt/mysql-data/ib*  
  2.  
  3. -rw-rw---- 1 mysql mysql 34M 03-02 23:18 /opt/mysql-data/ibdata1  
  4.  
  5. -rw-rw---- 1 mysql mysql 5.0M 03-02 23:18 /opt/mysql-data/ib_logfile0  
  6.  
  7. -rw-rw---- 1 mysql mysql 5.0M 12-22 20:19 /opt/mysql-data/ib_logfile1 

默认没有用INNODB的是10M,现在我的变成30M了。

修改工具

把MYISAM修改成INNODB

Vi /usr/local/mysql/bin/mysql_convert_table_format

把第26行$opt_type="innodb" 改成$opt_type="myisam"

用工具进行库的转换

   
   
  1. [root@test ~]# mysql_convert_table_format mo --user='root' --password='mysql' --socket='/tmp/mysql.sock' 
  2.  
  3. [root@test ~]# 

可能会出现以下异常

install_driver(mysql) failed: Can't locate DBD/mysql.pm in @INC (@INC contains: /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at (eval 3) line 3.
Perhaps the DBD::mysql perl module hasn't been fully installed,
or perhaps the capitalisation of 'mysql' isn't right.
Available drivers: DBM, ExampleP, File, Gofer, Proxy, Sponge.
 at /usr/bin/mysql_convert_table_format line 66

是因为mysql5.6默认不添加mysql-per依赖包,因此执行如下命令一路y就可以了

yum install perl-DBD-MySQL  也可以参考文章:http://blog.csdn.net/u010440155/article/details/54952721


成功完成,再看看数据文件:

   
   
  1. 总计 2568  
  2.  
  3. -rw-rw---- 1 mysql mysql 12914 03-02 23:18 action_log.frm  
  4.  
  5. -rw-rw---- 1 mysql mysql     0 03-02 23:18 action_log.MYD  
  6.  
  7. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 action_log.MYI  
  8.  
  9. -rw-rw---- 1 mysql mysql 8900 03-02 23:18 alarm_log.frm  
  10.  
  11. -rw-rw---- 1 mysql mysql     0 03-02 23:18 alarm_log.MYD  
  12.  
  13. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 alarm_log.MYI  
  14.  
  15. -rw-rw---- 1 mysql mysql 8898 03-02 23:18 check_data.frm  
  16.  
  17. -rw-rw---- 1 mysql mysql 8836 03-02 23:18 check_data_log.frm  
  18.  
  19. -rw-rw---- 1 mysql mysql 1708 03-02 23:18 check_data_log.par  
  20.  
  21. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p0.MYD  
  22.  
  23. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p0.MYI  
  24.  
  25. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p100.MYD  
  26.  
  27. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p100.MYI  
  28.  
  29. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p101.MYD  
  30.  
  31. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p101.MYI  
  32.  
  33. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p102.MYD  
  34.  
  35. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p102.MYI  
  36.  
  37. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p103.MYD  
  38.  
  39. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p103.MYI  
  40.  
  41. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p104.MYD  
  42.  
  43. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p104.MYI  
  44.  
  45. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p105.MYD  
  46.  
  47. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p105.MYI  
  48.  
  49. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p106.MYD  
  50.  
  51. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p106.MYI  
  52.  
  53. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p107.MYD  
  54.  
  55. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p107.MYI  
  56.  
  57. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p108.MYD  
  58.  
  59. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p108.MYI  
  60.  
  61. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p109.MYD  
  62.  
  63. -rw-rw---- 1 mysql mysql 1024 03-02 23:18 check_data_log#P#p109.MYI  
  64.  
  65. -rw-rw---- 1 mysql mysql     0 03-02 23:18 check_data_log#P#p10.MYD 

已经成功转换成MYISAM引擎。

关于使用mysql_convert_table_format工具来批量转换MySQL数据库表的存储引擎的方法就介绍到这里了,希望本次的介绍能够对您有所收获

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值