以质量求生存 以信誉求发展

专业电子专用材料,特种陶瓷制品,基础化学原料,有色金属及合金材料

全国服务热线

15973210079

热门关键词:电子专用材料,特种陶瓷制品,基础化学原料,有色金属及合金材料

政策动态

MySQL两种表存储结构性能比较测试过程

  • 时间:2019-04-06
  • 作者:深圳APP开发
  • 来源:
  • 阅读量:

 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不用事务表:

  CREATE TABLE `MyISAM_NT` (
  `TableId` int(11) NOT NULL default '0',
  `TableString` varchar(21) NOT NULL default ''
  ) ENGINE=MyISAM;

  2、MyISAM用事务表:

  CREATE TABLE `MyISAM_TS` (
  `TableId` int(11) NOT NULL default '0',
  `TableString` varchar(21) NOT NULL default ''
  ) ENGINE=MyISAM;

  3、InnoDB关闭AutoCommit,不用事务:

  CREATE TABLE `INNODB_NA_NB` (
  `TableId` int(11) NOT NULL default '0',
  `TableString` varchar(21) NOT NULL default ''
  ) ENGINE=InnoDB;

 

15973210079

二维码