MyISAM与InnoDB是mysql目前比较常用的两个数据库存储引擎,MyISAM与InnoDB的主要的不同点在于性能和事务控制上。这里简单的介绍一下两者间的区别和转换方法:

MyISAM:MyISAM是MySQL5.5之前版本默认的数据库存储引擎。MYISAM提供高速存储和检索,以及全文搜索能力,适合数据仓库等查询频繁的应用。但不支持事务、也不支持外键。MyISAM格式的一个重要缺陷就是不能在表损坏后恢复数据。

InnoDB:InnoDB是MySQL5.5版本的默认数据库存储引擎,不过InnoDB已被Oracle收购,MySQL自行开发的新存储引擎Falcon将在MySQL6.0版本引进。InnoDB具有提交、回滚和崩溃恢复能力的事务安全。但是比起MyISAM存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。尽管如此,但是InnoDB包括了对事务处理和外来键的支持,这两点都是MyISAM引擎所没有的。

MyISAM适合:(1)做很多count 的计算;(2)插入不频繁,查询非常频繁;(3)没有事务。
InnoDB适合:(1)可靠性要求比较高,或者要求事务;(2)表更新和查询都相当的频繁,并且表锁定的机会比较大的情况。(4)性能较好的服务器,比如单独的数据库服务器,像阿里云的关系型数据库RDS就推荐使用InnoDB引擎。

MySQL一般提供多种存储引擎,可以通过执行以下指令查看:

首先进入MySQL命令行模式

查看MySQL提供什么存储引擎:
mysql> show engines;

查看MySQL当前默认的存储引擎:
mysql> show variables like ‘%storage_engine%’;

查询wpsql库
mysql> use wpsql;

列出当前库所有表名
mysql> show tables;

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

将wp_posts表修为InnoDB存储引擎(也可以此命令将InnoDB换为MyISAM):
mysql> ALTER TABLE wp_posts ENGINE=INNODB;
如果要更改整个数据库表的存储引擎,一般要一个表一个表的修改,比较繁琐,可以采用先把数据库导出,得到SQL,把MyISAM全部替换为INNODB,再导入数据库的方式。

转换完毕后重启mysql
> service mysqld restart

【将INNODB类型表批量转换为MyISAM类型表的办法】
将以下文件另存为mysql.php,修改对应的数据库用户名、数据库名和密码。上传到网站下,访问该页面,会批量转换表引擎为MYISAM。

<?php
//连接数据库
$host=’localhost’;
$user=’mysql_username’;   //数据库用户名
$passwd=’mysql_password’; //密码
$db=’wordpressdb’; //数据库名称
$link= mysql_connect($host,$user,$passwd);
if (!$link) {
die(‘Could not connect: ‘.mysql_error() );
}
mysql_select_db( $db,$link ) or die (‘can\’t use’. $db . mysql_error());
$result=mysql_query(“show tables “) or die( mysql_error());
while($row=mysql_fetch_row($result)){
#echo $row[0];
#var_dump($row);
echo “$row[0] \n”;
mysql_query(“alter table $row[0] type=’MYISAM'”) or die (mysql_error());
}
#var_dump($result);
mysql_close($link);
?>

注意:转换前请先用数据库软件将数据库做一个sql文件备份,避免转换出现问题。若转移失败请检查my.ini里的“default-storage-engine”是否=“MyISAM”。另,由此转换导致的一切风险自行承担。