当前位置:首页 > PHP教程 > php高级应用 > 列表

php中读写文件与读写数据库的效率

发布:smiling 来源: PHP粉丝网  添加日期:2014-08-28 08:45:14 浏览: 评论:0 

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

测试实例代码如下: 

  1. //说明2:测试两次一次是4K数据,一次是整形数据 
  2.  
  3. set_time_limit(0); 
  4.  
  5. function fnGet($filename
  6.     $content = file_get_contents($filename); 
  7.     return $content
  8.  
  9. function fnGetContent($filename
  10.     $content = fnGet($filename); 
  11.     return $content
  12.      
  13. $times=100000;     
  14. echo '数据库查询结果:<br/>'
  15. //--------------------------------- 
  16. $begin=fnGetMicroTime(); 
  17. for($i=0;$i<$times;$i++) 
  18.     $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); 
  19.     $row=$dbcon->mydb_fetch_row($res); 
  20.     $content=$row[0]; 
  21. echo 'fetch_row '.$times.' 次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>'
  22. //--------------------------------- 
  23.  
  24. $begin=fnGetMicroTime(); 
  25. for($i=0;$i<$times;$i++) 
  26.     $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); 
  27.     $row=$dbcon->mydb_fetch_array($res); 
  28.     $content=$row['log_Content'];     
  29. echo 'fetch_array '.$times.' 次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>'
  30. //--------------------------------- 
  31.  
  32. $begin=fnGetMicroTime(); 
  33. for($i=0;$i<$times;$i++) 
  34.     $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); 
  35.     $row=$dbcon->mydb_fetch_object($res); 
  36.     $content=$row->log_Content;     
  37. echo 'fetch_object '.$times.' 次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>'
  38. //--------------------------------- 
  39.  
  40. $dbcon->mydb_free_results(); 
  41. $dbcon->mydb_disconnect(); 
  42.  
  43. fnWriteCache('test.txt',$content); 
  44.  
  45. echo '直接读文件测试结果:<br/>'
  46.  
  47. //--------------------------------- 
  48. $begin=fnGetMicroTime(); 
  49. for($i=0;$i<$times;$i++) 
  50.     $content = fnGetContent('test.txt'); 
  51. echo 'file_get_contents直接读'.$times.'次时间:<font color=red>'.(fnGetMicroTime()-$begin).'</font>秒<br/>'
  52. //--------------------------------- 
  53.  
  54. $begin=fnGetMicroTime(); 
  55. for($i=0;$i<$times;$i++) 
  56. {//开源代码phpfensi.com 
  57.     $fname = 'test.txt'
  58.     if(file_exists($fname)) 
  59.      { 
  60.         $fp=fopen($fname,"r");//flock($fp,LOCK_EX);         
  61.         $file_data=fread($fpfilesize($fname));//rewind($fp);        
  62.         fclose($fp); 
  63.     } 
  64.     $content = fnGetContent('test.txt'); 
  65. }     
  66. 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效率更高,这跟网上的说法似乎相反.

Tags: php读写文件 php读写数据库

分享到: