Maison  >  Article  >  base de données  >  读写文件与读写数据库的效率比较

读写文件与读写数据库的效率比较

WBOY
WBOYoriginal
2016-06-07 15:21:541820parcourir

读写文件与读写数据库的效率比较 说明1:由于读数据库语句调用简单的封包函数两次,所以把读文件也改成连续调用两次,数据库记录ID为1就在第一条,并且唯一索引。 说明2:测试两次一次是4K数据,一次是整形数据 1 set_time_limit(0); 2 3 function fnGet($fi

读写文件与读写数据库的效率比较

 

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

 

说明2:测试两次一次是4K数据,一次是整形数据

 

  1 set_time_limit(0);
  2 
  3 function fnGet($filename)
  4 
  5 {
  6 
  7 $content = file_get_contents($filename);
  8 
  9 return $content;
 10 
 11 }
 12 
 13 function fnGetContent($filename)
 14 
 15 {
 16 
 17 $content = fnGet($filename);
 18 
 19 return $content;
 20 
 21 }
 22 
 23 $times=100000;
 24 
 25 echo &#39;数据库查询结果:<br/>&#39;;
 26 
 27 //---------------------------------
 28 
 29 $begin=fnGetMicroTime();
 30 
 31 for($i=0;$i<$times;$i++)
 32 
 33 {
 34 
 35 $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID=&#39;1&#39;");
 36 
 37 $row=$dbcon->mydb_fetch_row($res);
 38 
 39 $content=$row[0];
 40 
 41 }
 42 
 43 echo &#39;fetch_row &#39;.$times.&#39; 次时间:<font color=red>&#39;.(fnGetMicroTime()-$begin).&#39;</font>秒<br/>&#39;;
 44 
 45 //---------------------------------
 46 
 47 $begin=fnGetMicroTime();
 48 
 49 for($i=0;$i<$times;$i++)
 50 
 51 {
 52 
 53 $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID=&#39;1&#39;");
 54 
 55 $row=$dbcon->mydb_fetch_array($res);
 56 
 57 $content=$row[&#39;log_Content&#39;];
 58 
 59 }
 60 
 61 echo &#39;fetch_array &#39;.$times.&#39; 次时间:<font color=red>&#39;.(fnGetMicroTime()-$begin).&#39;</font>秒<br/>&#39;;
 62 
 63 //---------------------------------
 64 
 65 $begin=fnGetMicroTime();
 66 
 67 for($i=0;$i<$times;$i++)
 68 
 69 {
 70 
 71 $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID=&#39;1&#39;");
 72 
 73 $row=$dbcon->mydb_fetch_object($res);
 74 
 75 $content=$row->log_Content;
 76 
 77 }
 78 
 79 echo &#39;fetch_object &#39;.$times.&#39; 次时间:<font color=red>&#39;.(fnGetMicroTime()-$begin).&#39;</font>秒<br/>&#39;;
 80 
 81 //---------------------------------
 82 
 83 $dbcon->mydb_free_results();
 84 
 85 $dbcon->mydb_disconnect();
 86 
 87 fnWriteCache(&#39;test.txt&#39;,$content);
 88 
 89 echo &#39;直接读文件测试结果:<br/>&#39;;
 90 
 91 //---------------------------------
 92 
 93 $begin=fnGetMicroTime();
 94 
 95 for($i=0;$i<$times;$i++)
 96 
 97 {
 98 
 99 $content = fnGetContent(&#39;test.txt&#39;);
100 
101 }
102 
103 echo &#39;file_get_contents直接读&#39;.$times.&#39;次时间:<font color=red>&#39;.(fnGetMicroTime()-$begin).&#39;</font>秒<br/>&#39;;
104 
105 //---------------------------------
106 
107 $begin=fnGetMicroTime();
108 
109 for($i=0;$i<$times;$i++)
110 
111 {
112 
113 $fname = &#39;test.txt&#39;;
114 
115 if(file_exists($fname))
116 
117 {
118 
119 $fp=fopen($fname,"r");//flock($fp,LOCK_EX);
120 
121 $file_data=fread($fp, filesize($fname));//rewind($fp);
122 
123 fclose($fp);
124 
125 }
126 
127 $content = fnGetContent(&#39;test.txt&#39;);
128 
129 }
130 
131 echo &#39;fopen直接读&#39;.$times.&#39;次时间:<font color=red>&#39;.(fnGetMicroTime()-$begin).&#39;</font>秒<br/>&#39;;

 

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

 

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn