首页  韩国资源  酷站加油  我的展厅  设计名站  古典元素  推荐下载  设计欣赏  每周专访  招募精英  人才专区  网页教程  平面设计  编程开发  设计竞赛
当前位置:首页 > 编程开发 > 数据库编程 > 正文
Google
MySQL两种表存储结构性能比较测试过程
来源:itpub.net 2007年12月17日 10:04 网友评论:0条 点击:

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

'''

MyISAM,InnoDB性能比较

作者:空心菜(Invalid)

时间:2004-10-22

'''

import MySQLdb

import sys

import os

import string

import time

c = None

testtables = [("MyISAM_NT",None,0),

("MyISAM_TS",None,1),

("INNODB_NA_NB",0,0),

("INNODB_NA_BE",0,1),

("INNODB_AU_NB",1,0),

("INNODB_AU_BE",1,1)

]

def BeginTrans():

print "ExecSQL:BEGIN;"

c.execute("BEGIN;"

return

def Commit():

print "ExecSQL:COMMIT;"

c.execute("COMMIT;"

return

def AutoCommit(flag):

print "ExecSQL:Set AUTOCOMMIT = "+str(flag)

c.execute("Set AUTOCOMMIT = "+str(flag))

return

def getcount(table):

#print "ExecSQL:select count(*) from "+table

c.execute("select count(*) from "+table)

return c.fetchall()[0][0]

def AddTable (Table,TableId,TableString):

sql = "INSERT INTO "+Table+"(TableId, TableString) VALUES( "+ TableId+ ",'" + TableString +"')"

try:

c.execute(sql)

except MySQLdb.OperationalError,error:

print "AddTable Error:",error

return -1;

return c.rowcount

def main():

argv = sys.argv

if len(argv) &lt 2:

print 'Usage:',argv[0],' TableId TestCount \n'

sys.exit(1)

首页 上一页 [1] [2] 下一页 尾页
上一篇:SQL Server数据库的实用技巧   下一篇:linux apache目录添加密码
收藏此页】【打印】【关闭
 相关文章  我要点评
·MySQL数据库只监听某个特定地址的方法
·数据仓库的数据存储和实现
·层次结构存储的两种设计方法
·MySQL对服务器端光标的限制
·MySQL数据库双机热备的配置方法
·存储过程中如何执行带输出参数的动态SQL
·MySQL根用户root密码忘记后的方法
·mysql数据库操作——DB类

免责声明:本站刊载此文不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。对本文有任何异议,请联络:68design#163.com
转载要求:作者及来源信息必需保留。转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印。



关于我们 | 在线反馈 | 广告报价 | 友情链接 | 联系我们 | 免责声明 | 在线投稿 | 网站地图
Copyright © 2003-2007 68design.net, All Rights Reserve 【找网页设计师,当然上网页设计师联盟】