MySQL两种表存储结构性能比较测试过程
|
源代码网整理以下MySQL支持的两种主要表存储格式MyISAM,InnoDB,上个月做个项目时,先使用了InnoDB,结果速度特别慢,1秒钟只能插入10几条。后来换成MyISAM格式,一秒钟插入上万条。当时觉的这两个表的性能也差别太大了吧。后来自己推测,不应该差别这么慢,估计是写的插入语句有问题,决定做个测试: 源代码网整理以下测试环境:Redhat Linux9,4CPU,内存2G,MySQL版本为4.1.6-gamma-standard 源代码网整理以下测试程序:Python+Python-MySQL模块。 源代码网整理以下测试方案: 源代码网整理以下1、MyISAM格式分别测试,事务和不用事务两种情况: 源代码网整理以下2、InnoDB格式分别测试AutoCommit=1(不用begin transaction和用begin transaction模式),AutoCommit=0 (不用begin transaction和用begin transaction模式)四种情况。 源代码网整理以下测试方法为插入10000条记录。为了测试不互相影响,单独建立了专用的测试表,建表语句如下: 源代码网整理以下1、MyISAM不用事务表: 源代码网整理以下
源代码网整理以下2、MyISAM用事务表: 源代码网整理以下
源代码网整理以下3、InnoDB关闭AutoCommit,不用事务: 源代码网整理以下
源代码网整理以下4、InnoDB关闭AutoCommit,用事务: 源代码网整理以下
源代码网整理以下5、InnoDB开启AutoCommit,不用事务: 源代码网整理以下
源代码网整理以下6、InnoDB开启AutoCommit,用事务: 源代码网整理以下
源代码网整理以下MyISAM,InnoDB性能比较 源代码网整理以下作者:空心菜(Invalid) 源代码网整理以下时间:2004-10-22 源代码网整理以下
源代码网整理以下#每次操作前都重写建立数据库连接 源代码网整理以下
源代码网整理以下结论: 源代码网整理以下由此得知影响速度的主要原因是AUTOCOMMIT默认设置是打开的, 源代码网整理以下我当时的程序没有显式调用BEGIN;开始事务,导致每插入一条都自动Commit,严重影响了速度。 源代码网整理以下算来也是个低级错误! 源代码网整理以下相关参考: 源代码网整理以下http://dev.mysql.com/doc/MySQL/en/COMMIT.html 源代码网整理以下http://dev.mysql.com/doc/MySQL/en/InnoDB_and_AUTOCOMMIT.html 源代码网供稿. |
