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

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 ~]# 

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

 
 
 
  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数据库表的存储引擎的方法就介绍到这里了,希望本次的介绍能够对您有所收获。

【编辑推荐】

  1. 关于MySQL数据库设计的几点优化措施
  2. MySQL数据库如何恰到好处地使用索引?
  3. PHP的MySQL库之Pdo-Mysql与Mysqli性能对比
  4. 一个mysql数据库配置问题导致登录失败的解决方案
  5. MySQL数据库打开文件太多导致mysqldump出错的解决

网站栏目:批量转换MySQL数据库表的存储引擎的方法
文章来源:http://www.csdahua.cn/qtweb/news0/340000.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网