Mysql更换MyISAM存储引擎为Innodb的操作记录

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

一般情况下,mysql会默认提供多种存储引擎,可以通过下面的查看:

1)查看mysql是否安装了innodb插件。
通过下面的命令结果可知,已经安装了innodb插件。

1
2
3
4
5
6
7
8
9
10
11
12
13
mysql> show plugins;
+ ------------+--------+----------------+---------+---------+
Name        | Status | Type           | Library | License |
+ ------------+--------+----------------+---------+---------+
| binlog     | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
| partition  | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
| CSV        | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
| MEMORY     | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
| InnoDB     | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
| MyISAM     | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
| MRG_MYISAM | ACTIVE | STORAGE ENGINE |  NULL     | GPL     |
+ ------------+--------+----------------+---------+---------+
rows  in  set  (0.00 sec)

----------------------------------------------------------------------
如果发现没有安装innodb插件,可以执行下面语句进行安装: 
mysql> install plugin innodb soname 'ha_innodb.so';
----------------------------------------------------------------------

2)查看mysql现在已提供什么存储引擎:

1
2
3
4
5
6
7
8
9
10
11
mysql> show engines;
+ ------------+---------+------------------------------------------------------------+--------------+------+------------+
| Engine     | Support | Comment                                                    | Transactions | XA   | Savepoints |
+ ------------+---------+------------------------------------------------------------+--------------+------+------------+
| MRG_MYISAM | YES     | Collection  of  identical MyISAM tables                      |  NO            NO    NO          |
| CSV        | YES     | CSV storage engine                                         |  NO            NO    NO          |
| MyISAM     |  DEFAULT  Default  engine  as  of  MySQL 3.23  with  great performance     |  NO            NO    NO          |
| InnoDB     | YES     | Supports transactions, row- level  locking,  and  foreign  keys | YES          | YES  | YES        |
| MEMORY     | YES     | Hash based, stored  in  memory, useful  for  temporary  tables  |  NO            NO    NO          |
+ ------------+---------+------------------------------------------------------------+--------------+------+------------+
rows  in  set  (0.00 sec)

3)查看mysql当前默认的存储引擎:

1
2
3
4
5
6
7
mysql> show variables  like  '%storage_engine%' ;
+ ----------------+--------+
| Variable_name  | Value  |
+ ----------------+--------+
| storage_engine | MyISAM |
+ ----------------+--------+
1 row  in  set  (0.00 sec)

4)看某个表用了什么引擎(在显示结果里参数engine后面的就表示该表当前用的存储引擎):
mysql> show create table 表名;

1
2
3
4
5
6
7
8
9
10
11
12
mysql> show  create  table  wx_share_log;
+ --------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
Table         Create  Table                                                                                                                                                                                                                                                                                                        |
+ --------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| wx_share_log |  CREATE  TABLE  `wx_share_log` (
   `id`  int (11)  NOT  NULL  AUTO_INCREMENT COMMENT  '微信分享日志自增ID' ,
   `reference_id`  int (11)  NOT  NULL  COMMENT  '推荐的经纪人id' ,
   `create_time` datetime  NOT  NULL  COMMENT  '创建时间' ,
   PRIMARY  KEY  (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=13  DEFAULT  CHARSET=utf8                   |
+ --------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row  in  set  (0.00 sec)

5)如何将MyISAM库导成INNODB引擎格式的:
在备份出的xxx.sql文件中把ENGINE=MyISAM全换成ENGINE=INNODB
再次导入就可以了。

6)转换表的命令:
mysql> alter table 表名 engine=innodb;

有上面可以查到看,本机mysql使用的存储引擎是默认的MyISAN,由于业务需要,先要将其存储引擎改为Innodb。
操作记录如下:

1)以安全模式关闭mysql
[root@dev mysql5.1.57]# mysqladmin -uroot -p shutdown
Enter password: 
[root@dev mysql5.1.57]# ps -ef|grep mysql

2)备份my.cnf
[root@dev mysql5.1.57]# cp my.cnf my.cnf.old

3)修改my.cnf配置文件
[root@dev mysql5.1.57]# vim my.cnf
.....
[mysqld]                                        //在这个配置区域添加下面一行,指定存储引擎为innodb
default-storage-engine = InnoDB

4)删除/mysql/data目录下的ib_logfile0,ib_logfile1。删除或剪切到别处都行。
[root@dev var]# mv ib_logfile0 ib_logfile1 /tmp/back/

5)启动mysql,登陆mysql验证存储引擎是否已切换
[root@dev var]# /Data/app/mysql5.1.57/bin/mysqld_safe --defaults-file=/Data/app/mysql5.1.57/my.cnf &

1
2
3
4
5
6
7
mysql> show variables  like  '%storage_engine%' ;
+ ----------------+--------+
| Variable_name  | Value  |
+ ----------------+--------+
| storage_engine | InnoDB |
+ ----------------+--------+
1 row  in  set  (0.00 sec)

 

***************当你发现自己的才华撑不起野心时,就请安静下来学习吧***************
本文转自散尽浮华博客园博客,原文链接:http://www.cnblogs.com/kevingrace/p/6230523.html ,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
存储 关系型数据库 MySQL
MySQL InnoDB数据存储结构
MySQL InnoDB数据存储结构
|
1月前
|
存储 缓存 关系型数据库
MySQL的varchar水真的太深了——InnoDB记录存储结构
varchar(M) 能存多少个字符,为什么提示最大16383?innodb怎么知道varchar真正有多长?记录为NULL,innodb如何处理?某个列数据占用的字节数非常多怎么办?影响每行实际可用空间的因素有哪些?本篇围绕innodb默认行格式dynamic来说说原理。
832 6
MySQL的varchar水真的太深了——InnoDB记录存储结构
|
1月前
|
SQL 关系型数据库 MySQL
Python怎么操作Mysql数据库
Python怎么操作Mysql数据库
51 0
|
1月前
|
SQL 关系型数据库 MySQL
python如何操作mysql数据库
python如何操作mysql数据库
24 0
|
21天前
|
存储 SQL 关系型数据库
【MySQL】4. 表的操作
【MySQL】4. 表的操作
21 0
|
1月前
|
SQL 关系型数据库 MySQL
|
12天前
|
存储 关系型数据库 MySQL
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
28 0
|
20天前
|
缓存 关系型数据库 MySQL
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
|
1月前
|
存储 缓存 关系型数据库
MySQL两种存储引擎及区别
MySQL两种存储引擎及区别
23 4
MySQL两种存储引擎及区别
|
15天前
|
存储 缓存 关系型数据库
mysql存储引擎
mysql存储引擎