网络编程
位置:首页>> 网络编程>> 数据库>> MySQL两种表存储结构性能比较测试过程

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

 来源:编程中国 发布时间:2007-12-09 12:45:00 

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


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; 


4、InnoDB关闭AutoCommit,用事务:


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


5、InnoDB开启AutoCommit,不用事务:


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


6、InnoDB开启AutoCommit,用事务:

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


测试的Python脚本如下:

#!/usr/bin/env Python
'''

0
投稿

猜你喜欢

  • select * from V$NLS_PARAMETERS; SQL> alter session set NLS_DATE_LAN
  • 已知有一个XML文件(bookstore.xml)如下:<?xml version="1.0" encoding=
  • 影响的范围: IE的所有版本在表单的radio/checkbox控件中,一旦他们的DOM结构被更改过就会出现这个bug。bug描述当象下例中
  • 秦歌这篇文章总结得很不错,俺挑刺来啦:1. 优先级的描述不严谨,有 !important 时,网页样式可以覆盖用户自定义样式。用户!impo
  • CSS如何做细线表格?天天用Div,倒把CSS表格细线这个最基础的应用忘了。table { border-collapse:&nb
  • 更轻量- 出色的颗粒化模块,子模块划分;- 延迟加载;- 强调代码重用(公共基类、插件、扩展);更易用- 统一的API;- 便利(each,
  • 网站设计时,有一个最常用的指导性原则:页面长度原则上不超过3屏,宽度不超过1屏。这个原则明显是从用户的体验出发,特别是宽度不超过一屏,其最基
  • 1. 选用适合的ORACLE优化器 ORACLE的优化器共有3种: a. RULE (基于规则) b. COST (基于成本) c. CHO
  • z-blog摘要图文混排,在月光的博客早已有介绍,但是他的图文混排是基于一篇文章只定义一个Tag的情况,对于我这样习惯多tag的博客,再更改
  • Function closeUBB(strContent) '*************************
  • 三遍记忆,让你记住海量素材的准确位置和用途,提高其可用性.这仅仅是一个示意图.在以往的日子里,我做到了只要脑袋里冒出一个想法,立刻就能知道我
  • 如何终止浏览器的 CAHCE 页面?Function Redirect( NewURL ) If&n
  • MySQL使用于认证目的的用户名,与Unix用户名(登录名字)或Windows用户名无关。缺省地,大多数MySQL客户尝试使用当前Unix用
  •   ASP日期和时间函数我们经常会用到,本文列出了12个常用的asp日期和时间函数的语法及用法以作备忘!1.Now Now() 取
  • 实现一个AuditLog的功能,是B/S结构专案。 每个用户可以登录系统,在程序中操作数据(添加,更新和删除)需要实现记录操作跟踪。是谁添加
  • Hello, 大家好,又是我~ 大家有看过font set和一些要注意的基本问题以及通用字体族两篇文章后,应该对字体的基本有了一些了解。现
  • 摘要:下拉菜单经常带来更多的可用性问题,并且常常容易被混淆。这是因为网页设计师们往往会在不同的几种情况下使用它。同时,滚动的菜单降低了网页的
  • 通过《SQL Server 数据库备份和还原认识和总结(一)》,相信您对数据备份和还原有了一个更深入的认识,在上文中我没有对事务日志做剖析,
  • 首先建一个access 数据库,库中有一个URLINDEX表,其中URL和Keywords字段分别添加了索引,如下:URL &nb
  • Cookies,有些人喜欢它们,有些人憎恨它们。但是,很少有人真正知道如何使用它们。现在你可以成为少数人中的成员-可以自傲的Cookie 大
手机版 网络编程 asp之家 www.aspxhome.com