用PHP连mysql和oracle数据库性能比较

发布:webn 2005-10-24 13:17 阅读:4975
用PHP连mysql和oracle数据库性能比较 fJ lN'F7  
9i)mv/i  
测试硬件说明: !3v"7l{LF  
测试使用的是我的爱机,配置如下: OQ*. ho  
CPU:C433 j/ IZm)\  
内存:128M zLK ~i>aW  
硬盘:酷鱼2代20G m95$V&  
toZI.cSg4  
测试软件说明: 3E@&wpj  
WIN32下用的是windows nt server4,sp5,apache 1.3.12,php3.0.15和php4rc1,mysql 3.22.29,oracle 8.0.5 Xz@;`>8i  
linux下用的是bluepoint linux1.0, apache 1.3.12, php4rc1,mysql 3.22.32  M!DoR6  
l"!;Vkg.5  
测试代码说明: Ph_m'fbf  
使用一个很简单的表,mysql和oracle使用的表结构是一样的,都只有三个字段,结构如下: WbzL!zLd!  
mysql的表结构: ,#;ahwU~s  
CREATE TABLE board ( LVtQ^ 5>8  
board_id smallint(6) NOT NULL auto_increment, }4MG114j  
board_name char(16) NOT NULL, %4^/.) Q  
board_manager char(20), #_|^C(]!  
PRIMARY KEY (board_id) eh(]'%![/  
); g%P4$|C9 i  
oracle的结构: <aD+Ki6  
CREATE TABLE PHP_ORACLE."BOARD" 8~+Msn:  
("BOARD_ID" FLOAT, *4VP5]!  
"BOARD_NAME" CHAR(16) NOT NULL, M8Lj*JN  
"BOARD_MANAGER" CHAR(20)) ; L%s""nP  
}X:r:{r  
我们只测试了INSERT操作花的时间,对于select,并未作测试。 O5%F-}(:  
因为win32下只有PHP3才能连接oracle数据库,所以只测试了用PHP3连接oracle的性能。相 mW9b~G3k  
信在PHP4的正式版本出来后,用PHP4连接oracle的速度应该有所提升。 U}Fk%Jj  
而在LINUX下,因为我没有装oracle,所以只测试了mysql的性能。据说在LINUX下,oracle <Y6>L};  
的性能不错,只是无法测试。 'Em($A (  
并且我们将所有的用于数据库连接和oracle用来分析sql语句的代码都放在了统计代码之外 NVPYv#uK  
,所以测试得出的时间只是用于执行SQL操作所花费的时间。 5X-{|r3q  
u)MA#p {  
用来测试mysql的程序: b#^D8_9h  
t\0JNi$2  
<?php >R-$JrU.=  
$dblink=mysql_connect("localhost","root","shh123"); J>v>6OC6i  
mysql_select_db("bbs"); ]`m5!V_Y  
$counter=1; |(g2fByDf  
set_time_limit(300); Bqgw%_  
$query="insert into board (board_name,board_manager) values ('test','test')"; cIkLdh   
$begin_time=time(); [0@i,7{ZqE  
for ($i=1;$i<=10000;$i++){ YI+|6s[  
mysql_db_query("bbs",$query); IrM3Uh  
$counter++; ,%<77LE  
} KWMH|sxO=  
$end_time=time(); 0CYI,V  
mysql_close($dblink); vM8]fSc  
echo "test db speed...<br>"; ~!u94_:  
echo "begin time:".$begin_time."<BR>"; -fn~y1  
echo "<BR>end time:".$end_time."<BR>"; M-t9zT  
$total=$end_time-$begin_time; _JoA=< O!  
echo "total spent time:".$total; l6O(+*6Us  
?> ? ~8V;Qn  
W;W\L? r  
用来测试oracle的程序: sS|5x  
pTd@i1%Nr  
<?php ::w%rv  
$handle=OCILogon("php_oracle","php_oracle"); 35et+9  
<L 0_< T  
$counter=1; E2cmT$6  
set_time_limit(300); ymu#u   
$query="insert into board (board_id,board_name,board_manager) values (:board_id,'test','test')"; >ZWm0nTr  
$state=OCIParse($handle, $query); ps [rYy  
OCIBindByName($state, ":board_id", &$i,32); |ESe=G  
$begin_time=time(); QG ia(  
for ($i=1;$i<=10000;$i++){ $ :/1U$  
ociexecute($state); PeZ=ONY5  
} ]RJ2`xf  
$end_time=time(); 4BX*-t  
OCIFreeStatement($state); s RB8 jY  
ocilogoff($handle); 57rP@,vj  
echo "test db speed...<br>"; O,PHAwVG%L  
echo "begin time:".$begin_time."<BR>"; Hr'#0fW  
echo "<BR>end time:".$end_time."<BR>"; r\?*?sL  
$total=$end_time-$begin_time; eyOAG4QTV  
echo "total spent time:".$total; hw1s^:|+2  
?> Q&7Qht:ea:  
iZF{9@  
测试结果: +{&g|V  
B _ >|Mo/  
环境:win32+apache+php4+mysql [;}c@  
结果:28秒 "wc $'7M  
7}MWmS^8j  
环境:win32+apache+php3+mysql =W?c1EPLCx  
结果:34秒 l\)Q3.w  
l1msXBC  
环境:win32+apache+php3+oracle8.0.5(oci函数) @g{ " E6  
结果:46秒 ?0F#\0  
`1dr$U  
环境:linux+apache+php4+mysql X9>ujgK  
结果:10秒 _*_zyWW_j  
]d0Dd")n  
结论: lB3X1e9  
在WIN32下,mysql的性能虽然不是很好,但和oracle8比起来,还是要快很多,尤其是我在 Aka`L:k  
测试程序中,并没有将数据库连接的语句包括进来,所以这个测试结果只是插入数据所花费 -M:.D3,L  
的时间,而oracle的连接,天,太慢了!在我的机器上,连接一次,至少1-2秒钟。 7u;B[qH  
而在LINUX下,mysql的性能相对于在WIN32下,又有了一个很大的飞跃。由28秒骤减到10秒。 .(krB% N  
所以,如果你不需要存储过程的支持,并且数据库量不是大的那么惊人的话,还是在LINUX FM5$83Q  
下使用mysql作为你的数据库吧!这个轻量级的数据库可以给你最佳的性能、可管理性和相 Sq,x@  
当不错的安全性。 1*5n}cU~  
q\\J9`Q$J  
   大家快到这里继续学习其他的知识: http://www.now.net.cn/support/ R_csKj  
+KZc"0?  
   提供免费咨询电话 : http://www.now.net.cn/customer/moreline.net & b%6pVj  
Mg].#  
    QQ咨询:168075865   188092185 B{Rig5Sc  
    聯系電話:0756-2623870 QP'* )gjO7  
    !zeBxR$&o  
   大家懂了吗?懂了就要说懂,不懂就要说不懂,你不能懂了说你没懂,没懂反而说懂了,懂就是懂,不懂就是不懂...哎呦,谁拿臭鸡蛋丢我? 我话还没说完啊 jWQB~XQY  
hd900LA}  
  〓优惠套餐PHP系列推荐: 8164SWB  
  ⊙商务B型主机 送国家顶级CN域名或国际域名·送800M 空间邮箱·送GCDN 网站加速及镜像引擎·送繁简通网络简装版     1350 元/年 i ):el=  
FU<rE&X2:  
  ⊙虚拟专用B型主机 送国家顶级CN域名或国际域名·送2000M VIP企业邮局·送GCDN 网站加速及镜像引擎·送繁简通网络商务版 3800 元/年 1BF+sT3  
DZvpt%q  
    更多优惠,详情请见: http://www.now.net.cn/special/ {)G3*>sG3  
Z@>>ZS1Do  
▲商务C型主机+.CN 1650 元/年 ,免费加送CDN网站加速器 送繁简通网络简装版 8.@ yD^'  
    500独立空间,支持ASP/ASP.NET免费送800Mb邮箱Win20 k[][Md2Vh  
    03,IIS 6.0,支持50M SQLSERVER 2000ACCESS 数据库 l{ k   
    提供计数器,留言板脚本列表 ASP ASP.NET Active Z]aSo07  
    Perl CGIASP.NET 1.1 Microsoft Front Page 2000 扩 展 *J6qL! ["  
    $*tuv ?  
  ▲ 虚拟专用型C+.CN域名 4000 元/年  免费加送CDN网站加速器 送繁简通网络简装版 \.{?TB  
  dX<UruPA  
    送2000M VIP 企业邮局 支持ASP/ASP.NET免费送800Mb 79&Mc,69  
    邮箱Win2003,IIS 6.0,支持50M SQLSERVER cq/)Yff@:  
    2000ACCESS 数据库提供计数器,留言板脚本列表 ASP G|o-C:~  
    ASP.NET Active Perl CGIASP.NET 1.1 ym:JtI69   
    MicrosoftFront Page 2000 扩展,支持虚拟目录。 n_5g:`Y  
zX3O_  
  详情请点击: http://www.now.net.cn/host !-: a`Vs+  
  全球免费咨询电话,请点击 http://now.net.cn/customer/moreline.net -Z:al\e<g  
  聯系電話:0756-2623870   QQ咨询:168075865   188092185
分享到:

最新评论

pclover 2005-11-01 11:51
看过广告,谢谢。
我要发表 我要评论
限 50000 字节
关于我们
网站介绍
免责声明
加入我们
赞助我们
服务项目
稿件投递
广告投放
人才招聘
团购天下
帮助中心
新手入门
发帖回帖
充值VIP
其它功能
站内工具
清除Cookies
无图版
手机浏览
网站统计
交流方式
联系邮箱:广告合作 站务处理
微信公众号:opticsky 微信号:cyqdesign
新浪微博:光行天下OPTICSKY
QQ号:9652202
主办方:成都光行天下科技有限公司
Copyright © 2005-2025 光行天下 蜀ICP备06003254号-1