php中读写文件与读写数据库的效率比较分享


Posted in PHP onOctober 19, 2013

这个问题也是最近才想到的,就是到底读文件更快还是读数据库更快,能快多少,天缘也搜索过,没见有网友就这个问题答复过,也可能是太简单的缘故,我们本文还是来实测一下,由于时间关系,VC还没装,天缘先用PHP测试了一下,下次有时间在C/C++上补充测试到本文来,因为PHP的底层解析应该也是基于C的,所以估计两者环境测试结果差不多,小问题大收获,现在就来看一下测试过程及结果。

测试程序如下:

说明1:由于读数据库语句调用简单的封包函数两次,所以把读文件也改成连续调用两次,数据库记录ID为1就在第一条,并且唯一索引。
说明2:测试两次一次是4K数据,一次是整形数据

set_time_limit(0);
function fnGet($filename)
{
$content = file_get_contents($filename);
return $content;
}
function fnGetContent($filename)
{
$content = fnGet($filename);
return $content;
}
$times=100000;
echo '数据库查询结果:<br/>';
//---------------------------------
$begin=fnGetMicroTime();
for($i=0;$i<$times;$i++)
{
$res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'");
$row=$dbcon->mydb_fetch_row($res);
$content=$row[0];
}
echo 'fetch_row '.$times.' 次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>';
//---------------------------------
$begin=fnGetMicroTime();
for($i=0;$i<$times;$i++)
{
$res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'");
$row=$dbcon->mydb_fetch_array($res);
$content=$row['log_Content'];
}
echo 'fetch_array '.$times.' 次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>';
//---------------------------------
$begin=fnGetMicroTime();
for($i=0;$i<$times;$i++)
{
$res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'");
$row=$dbcon->mydb_fetch_object($res);
$content=$row->log_Content;
}
echo 'fetch_object '.$times.' 次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>';
//---------------------------------
$dbcon->mydb_free_results();
$dbcon->mydb_disconnect();
fnWriteCache('test.txt',$content);
echo '直接读文件测试结果:<br/>';
//---------------------------------
$begin=fnGetMicroTime();
for($i=0;$i<$times;$i++)
{
$content = fnGetContent('test.txt');
}
echo 'file_get_contents直接读'.$times.'次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>';
//---------------------------------
$begin=fnGetMicroTime();
for($i=0;$i<$times;$i++)
{
$fname = 'test.txt';
if(file_exists($fname))
{
$fp=fopen($fname,"r");//flock($fp,LOCK_EX);
$file_data=fread($fp, filesize($fname));//rewind($fp);
fclose($fp);
}
$content = fnGetContent('test.txt');
}
echo 'fopen直接读'.$times.'次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>';

4K大小数据的查询结果:
fetch_row 100000 次时间:16.737720012665秒
fetch_array 100000 次时间:16.661195993423秒
fetch_object 100000 次时间:16.775065898895秒
直接读文件测试结果:
file_get_contents直接读100000次时间:5.4631857872009秒
fopen直接读100000次时间:11.463611125946秒
整形ID查询结果:
fetch_row 100000 次时间:12.812072038651秒
fetch_array 100000 次时间:12.667390108109秒
fetch_object 100000 次时间:12.988099098206秒
直接读文件测试结果:
file_get_contents直接读100000次时间:5.6616430282593秒
fopen直接读100000次时间:11.542816877365秒

测试结论:

1、直接读文件相比数据库查询效率更胜一筹,而且文中还没算上连接和断开的时间。
2、一次读取的内容越大,直接读文件的优势会越明显(读文件时间都是小幅增长,这跟文件存储的连续性和簇大小等有关系),这个结果恰恰跟天缘预料的相反,说明MYSQL对更大文件读取可能又附加了某些操作(两次时间增长了近30%),如果只是单纯的赋值转换应该是差异偏小才对。
3、写文件和INSERT几乎不用测试就可以推测出,数据库效率只会更差。
4、很小的配置文件如果不需要使用到数据库特性,更加适合放到独立文件里存取,无需单独创建数据表或记录,很大的文件比如图片、音乐等采用文件存储更为方便,只把路径或缩略图等索引信息放到数据库里更合理一些。
5、PHP上如果只是读文件,file_get_contents比fopen、fclose更有效率,不包括判断存在这个函数时间会少3秒左右。
6、fetch_row和fetch_object应该是从fetch_array转换而来的,我没看过PHP的源码,单从执行上就可以说明fetch_array效率更高,这跟网上的说法似乎相反。
实际上在做这个试验之前,从个人经验判断就有了大概的结果,测试完成后则有种豁然开朗的感觉。假定在程序效率和关键过程相当且不计入缓存等措施的条件下,读写任何类型的数据都没有直接操作文件来的快,不论MSYQL过程如何,最后都要到磁盘上去读这个“文件”(记录存储区等效),所以当然这一切的前提是只读内容,无关任何排序或查找操作。

PHP 相关文章推荐
PHP查询MySQL大量数据的时候内存占用分析
Jul 22 PHP
thinkphp3查询mssql数据库乱码解决方法分享
Feb 11 PHP
php实现信用卡校验位算法THE LUHN MOD-10示例
May 07 PHP
php格式化日期实例分析
Nov 12 PHP
php超快高效率统计大文件行数
Jul 05 PHP
php上传图片生成缩略图(GD库)
Jan 06 PHP
PHP中的多种加密技术及代码示例解析
Oct 20 PHP
php创建图像具体步骤
Mar 13 PHP
详解php中serialize()和unserialize()函数
Jul 08 PHP
PHP实现创建微信自定义菜单的方法示例
Jul 14 PHP
基于ThinkPHP5.0实现图片上传插件
Sep 25 PHP
php7 参数、整形及字符串处理机制修改实例分析
May 25 PHP
PHP中include与require使用方法区别详解
Oct 19 #PHP
php文件上传的简单实例
Oct 19 #PHP
php上传文件,创建递归目录的实例代码
Oct 18 #PHP
php用户注册页面利用js进行表单验证具体实例
Oct 17 #PHP
10 个经典PHP函数
Oct 17 #PHP
php中怎么搜索相关联数组键值及获取之
Oct 17 #PHP
php class类的用法详细总结
Oct 17 #PHP
You might like
php 服务器调试 Zend Debugger 的安装教程
2009/09/25 PHP
IIS6.0中配置php服务全过程解析
2013/08/07 PHP
php设计模式之单例模式实例分析
2015/02/25 PHP
帝国CMS留言板回复后发送EMAIL通知客户
2015/07/06 PHP
Laravel+jQuery实现AJAX分页效果
2016/09/14 PHP
深入解析PHP底层机制及相关原理
2020/12/11 PHP
javascript在一段文字中的光标处插入其他文字
2007/08/26 Javascript
node.js中的fs.renameSync方法使用说明
2014/12/16 Javascript
drag-and-drop实现图片浏览器预览
2015/08/06 Javascript
JavaScript与HTML的结合方法详解
2015/11/23 Javascript
KnockoutJs快速入门教程
2016/05/16 Javascript
深入理解node exports和module.exports区别
2016/06/01 Javascript
nodejs后台集成ueditor富文本编辑器的实例
2017/07/11 NodeJs
jQuery创建及操作xml格式数据示例
2018/05/26 jQuery
详解微信JS-SDK选择图片遇到的坑
2018/08/15 Javascript
vue 导航内容设置选中状态样式的例子
2019/11/01 Javascript
vue实现整屏滚动切换
2020/06/29 Javascript
Python numpy实现数组合并实例(vstack,hstack)
2018/01/09 Python
Python中 传递值 和 传递引用 的区别解析
2018/02/22 Python
浅谈python中对于json写入txt文件的编码问题
2018/06/07 Python
Python3 pickle对象串行化代码实例解析
2020/03/23 Python
使用卷积神经网络(CNN)做人脸识别的示例代码
2020/03/27 Python
鞋子女王塔玛拉·梅隆同名奢侈品牌:Tamara Mellon
2017/11/22 全球购物
在线购买澳大利亚设计师手拿包和奢华晚装手袋:Olga Berg
2019/03/20 全球购物
伯克斯奥特莱斯:Burkes Outlet
2019/03/30 全球购物
法学毕业生自我鉴定
2014/01/31 职场文书
电脑售后服务承诺书
2014/03/27 职场文书
工商管理本科生求职信
2014/07/13 职场文书
学生安全责任书模板
2014/07/25 职场文书
乡镇精神文明建设汇报材料
2014/08/15 职场文书
团队拓展活动总结
2014/08/27 职场文书
市场营销工作计划书
2014/09/15 职场文书
群众路线教育实践活动学习笔记内容
2014/11/06 职场文书
承诺书的签字人,需不需要承担相应的责任?
2019/07/09 职场文书
创业计划书之珠宝饰品
2019/08/26 职场文书
Nginx如何配置根据路径转发详解
2022/07/23 Servers