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


Posted in PHP onOctober 09, 2006

测试硬件说明:
测试使用的是我的爱机,配置如下:
CPU:C433
内存:128M
硬盘:酷鱼2代20G

测试软件说明:
WIN32下用的是windows nt server4,sp5,apache 1.3.12,php3.0.15和php4rc1,mysql 3.22.29,oracle 8.0.5
linux下用的是bluepoint linux1.0, apache 1.3.12, php4rc1,mysql 3.22.32

测试代码说明:
使用一个很简单的表,mysql和oracle使用的表结构是一样的,都只有三个字段,结构如下:
mysql的表结构:
CREATE TABLE board (
   board_id smallint(6) NOT NULL auto_increment,
   board_name char(16) NOT NULL,
   board_manager char(20),
   PRIMARY KEY (board_id)
);
oracle的结构:
CREATE TABLE PHP_ORACLE."BOARD"
       ("BOARD_ID" FLOAT,
       "BOARD_NAME" CHAR(16) NOT NULL,
       "BOARD_MANAGER" CHAR(20)) ;

我们只测试了INSERT操作花的时间,对于select,并未作测试。
因为win32下只有PHP3才能连接oracle数据库,所以只测试了用PHP3连接oracle的性能。相 信在PHP4的正式版本出来后,用PHP4连接oracle的速度应该有所提升。
而在LINUX下,因为我没有装oracle,所以只测试了mysql的性能。据说在LINUX下,oracle 的性能不错,只是无法测试。
并且我们将所有的用于数据库连接和oracle用来分析sql语句的代码都放在了统计代码之外 ,所以测试得出的时间只是用于执行SQL操作所花费的时间。

用来测试mysql的程序:

<?php
$dblink=mysql_connect("localhost","root","shh123");
mysql_select_db("bbs");
$counter=1;
set_time_limit(300);
$query="insert into board (board_name,board_manager) values ('test','test')";
$begin_time=time();
for ($i=1;$i<=10000;$i++){
        mysql_db_query("bbs",$query);
    $counter++;
}
$end_time=time();
mysql_close($dblink);
echo "test db speed...<br>";
echo "begin time:".$begin_time."<BR>";
echo "<BR>end time:".$end_time."<BR>";
$total=$end_time-$begin_time;
echo "total spent time:".$total;
?>

用来测试oracle的程序:

<?php
$handle=OCILogon("php_oracle","php_oracle");

$counter=1;
set_time_limit(300);
$query="insert into board (board_id,board_name,board_manager) values (:board_id,'test','test')";
$state=OCIParse($handle, $query);
OCIBindByName($state, ":board_id", &$i,32);
$begin_time=time();
for ($i=1;$i<=10000;$i++){
        ociexecute($state);
}
$end_time=time();
OCIFreeStatement($state);
ocilogoff($handle);
echo "test db speed...<br>";
echo "begin time:".$begin_time."<BR>";
echo "<BR>end time:".$end_time."<BR>";
$total=$end_time-$begin_time;
echo "total spent time:".$total;
?>

测试结果:

环境:win32+apache+php4+mysql
结果:28秒

环境:win32+apache+php3+mysql
结果:34秒

环境:win32+apache+php3+oracle8.0.5(oci函数)
结果:46秒

环境:linux+apache+php4+mysql
结果:10秒

结论:
在WIN32下,mysql的性能虽然不是很好,但和oracle8比起来,还是要快很多,尤其是我在 测试程序中,并没有将数据库连接的语句包括进来,所以这个测试结果只是插入数据所花费 的时间,而oracle的连接,天,太慢了!在我的机器上,连接一次,至少1-2秒钟。 而在LINUX下,mysql的性能相对于在WIN32下,又有了一个很大的飞跃。由28秒骤减到10秒。 所以,如果你不需要存储过程的支持,并且数据库量不是大的那么惊人的话,还是在LINUX 下使用mysql作为你的数据库吧!这个轻量级的数据库可以给你最佳的性能、可管理性和相 当不错的安全性。 

PHP 相关文章推荐
关于PHP内存溢出问题的解决方法
Jun 25 PHP
php中simplexml_load_string使用实例分享
Feb 13 PHP
浅谈php函数serialize()与unserialize()的使用方法
Aug 19 PHP
PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
Sep 27 PHP
CodeIgniter使用smtp服务发送html邮件的方法
Jun 10 PHP
PHP+Mysql基于事务处理实现转账功能的方法
Jul 08 PHP
php+ajax实现无刷新数据分页的办法
Nov 02 PHP
php 三元运算符实例详细介绍
Dec 15 PHP
Redis在Laravel项目中的应用实例详解
Aug 11 PHP
PHP实现通过CURL上传文件功能示例
May 30 PHP
PHP使用pdo连接access数据库并循环显示数据操作示例
Jun 05 PHP
laravel框架之数据库查出来的对象实现转化为数组
Oct 23 PHP
利用文件属性结合Session实现在线人数统计
Oct 09 #PHP
PHP中上传大体积文件时需要的设置
Oct 09 #PHP
新版PHP极大的增强功能和性能
Oct 09 #PHP
用PHP开发GUI
Oct 09 #PHP
PHP中实现进程间通讯
Oct 09 #PHP
PHP利用COM对象访问SQLServer、Access
Oct 09 #PHP
新版mysql+apache+php Linux安装指南
Oct 09 #PHP
You might like
PHP中变量引用与变量销毁机制分析
2014/11/15 PHP
PHP memcache在微信公众平台的应用方法示例
2017/09/13 PHP
javascript(jquery)利用函数修改全局变量的代码
2009/11/02 Javascript
parseInt parseFloat js字符串转换数字
2010/08/01 Javascript
Ajax搜索结果页面下方的分页按钮的生成
2012/04/05 Javascript
Javascript遍历Html Table示例(包括内容和属性值)
2014/07/08 Javascript
js实现鼠标悬停图片上时滚动文字说明的方法
2015/02/17 Javascript
jQuery实现点击后高亮背景固定显示的菜单效果【附demo源码下载】
2016/09/21 Javascript
BootStrap Datepicker 插件修改为默认中文的实现方法
2017/02/10 Javascript
数组Array的排序sort方法
2017/02/17 Javascript
nodejs读写json文件的简单方法(必看)
2017/03/09 NodeJs
详解使用vue脚手架工具搭建vue-webpack项目
2017/05/10 Javascript
Angular实现响应式表单
2017/08/04 Javascript
详解vue-cli 快速搭建单页应用之遇到的问题及解决办法
2018/03/01 Javascript
Vue多系统切换实现方案
2018/06/05 Javascript
微信小程序实现滑动切换自定义页码的方法分析
2018/12/29 Javascript
javascript导出csv文件(excel)的方法示例
2019/08/25 Javascript
JS页面获取 session 值,作用域和闭包学习笔记
2019/10/16 Javascript
Python爬虫实现网页信息抓取功能示例【URL与正则模块】
2017/05/18 Python
基于python批量处理dat文件及科学计算方法详解
2018/05/08 Python
Python unittest单元测试框架总结
2018/09/08 Python
pandas中的series数据类型详解
2019/07/06 Python
Python之变量类型和if判断方式
2020/05/05 Python
Python经典五人分鱼实例讲解
2021/01/04 Python
乌克兰网上服装店:Bolf.ua
2018/10/30 全球购物
世界上最伟大的马产品:Equiderma
2020/01/07 全球购物
华为菲律宾官方网站:HUAWEI Philippines
2021/02/23 全球购物
银行门卫岗位职责
2013/12/29 职场文书
英语一分钟演讲稿
2014/04/29 职场文书
学校督导评估方案
2014/06/10 职场文书
医院搬迁方案
2014/06/14 职场文书
县长“四风”对照检查材料思想汇报
2014/10/05 职场文书
2014年房地产销售工作总结
2014/12/01 职场文书
《金色的草地》教学反思
2016/02/17 职场文书
单身狗福利?Python爬取某婚恋网征婚数据
2021/06/03 Python
Python anaconda安装库命令详解
2021/10/16 Python