Rumah  >  Artikel  >  pembangunan bahagian belakang  >  php读写文件与读写数据库的效率对比分析

php读写文件与读写数据库的效率对比分析

WBOY
WBOYasal
2016-07-25 08:57:34969semak imbas
  1. set_time_limit(0);
  2. function fnGet($filename)
  3. {
  4. $content = file_get_contents($filename);
  5. return $content;
  6. }
  7. function fnGetContent($filename)
  8. {
  9. $content = fnGet($filename);
  10. return $content;
  11. }
  12. $times=100000;
  13. echo '数据库查询结果:
    ';
  14. //---------------------------------
  15. $begin=fnGetMicroTime();
  16. for($i=0;$i{
  17. $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'");
  18. $row=$dbcon->mydb_fetch_row($res);
  19. $content=$row[0];
  20. }
  21. echo 'fetch_row '.$times.' 次时间:'.(fnGetMicroTime()-$begin).'
    ';
  22. //---------------------------------
  23. $begin=fnGetMicroTime();
  24. for($i=0;$i{
  25. $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'");
  26. $row=$dbcon->mydb_fetch_array($res);
  27. $content=$row['log_Content'];
  28. }
  29. echo 'fetch_array '.$times.' 次时间:'.(fnGetMicroTime()-$begin).'
    ';
  30. //---------------------------------
  31. $begin=fnGetMicroTime();
  32. for($i=0;$i{
  33. $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'");
  34. $row=$dbcon->mydb_fetch_object($res);
  35. $content=$row->log_Content;
  36. }
  37. echo 'fetch_object '.$times.' 次时间:'.(fnGetMicroTime()-$begin).'
    ';
  38. //---------------------------------
  39. $dbcon->mydb_free_results();
  40. $dbcon->mydb_disconnect();
  41. fnWriteCache('test.txt',$content);
  42. echo '直接读文件测试结果:
    ';
  43. //---------------------------------
  44. $begin=fnGetMicroTime();
  45. for($i=0;$i{
  46. $content = fnGetContent('test.txt');
  47. }
  48. echo 'file_get_contents直接读'.$times.'次时间:'.(fnGetMicroTime()-$begin).'
    ';
  49. //---------------------------------
  50. $begin=fnGetMicroTime();
  51. for($i=0;$i{
  52. $fname = 'test.txt';
  53. if(file_exists($fname))
  54. {
  55. $fp=fopen($fname,"r");//flock($fp,LOCK_EX);
  56. $file_data=fread($fp, filesize($fname));//rewind($fp);
  57. fclose($fp);
  58. }
  59. $content = fnGetContent('test.txt');
  60. }
  61. echo 'fopen直接读'.$times.'次时间:'.(fnGetMicroTime()-$begin).'
    ';
复制代码

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过程如何,最后都要到磁盘上去读这个“文件”(记录存储区等效),所以当然这一切的前提是只读内容,无关任何排序或查找操作。



Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:php内链关键词替换函数 Artikel seterusnya:php getdate函数用法举例