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

您所在的位置:网站首页 php读文件快还是读数据库快 读写文件与读写数据库的效率比较

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

2024-04-17 20:03| 来源: 网络整理| 查看: 265

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

测试程序如下:

说明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 '数据库查询结果:'; 26 27 //--------------------------------- 28 29 $begin=fnGetMicroTime(); 30 31 for($i=0;$imydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); 36 37 $row=$dbcon->mydb_fetch_row($res); 38 39 $content=$row[0]; 40 41 } 42 43 echo 'fetch_row '.$times.' 次时间:'.(fnGetMicroTime()-$begin).'秒'; 44 45 //--------------------------------- 46 47 $begin=fnGetMicroTime(); 48 49 for($i=0;$imydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); 54 55 $row=$dbcon->mydb_fetch_array($res); 56 57 $content=$row['log_Content']; 58 59 } 60 61 echo 'fetch_array '.$times.' 次时间:'.(fnGetMicroTime()-$begin).'秒'; 62 63 //--------------------------------- 64 65 $begin=fnGetMicroTime(); 66 67 for($i=0;$imydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); 72 73 $row=$dbcon->mydb_fetch_object($res); 74 75 $content=$row->log_Content; 76 77 } 78 79 echo 'fetch_object '.$times.' 次时间:'.(fnGetMicroTime()-$begin).'秒'; 80 81 //--------------------------------- 82 83 $dbcon->mydb_free_results(); 84 85 $dbcon->mydb_disconnect(); 86 87 fnWriteCache('test.txt',$content); 88 89 echo '直接读文件测试结果:'; 90 91 //--------------------------------- 92 93 $begin=fnGetMicroTime(); 94 95 for($i=0;$i


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3