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

发表于:2013-10-23 09:35

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:南方侯鸟    来源:51Testing软件测试网采编

  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过程如何,最后都要到磁盘上去读这个“文件”(记录存储区等效),所以当然这一切的前提是只读内容,无关任何排序或查找操作。
22/2<12
《2023软件测试行业现状调查报告》独家发布~

精彩评论

  • acttest
    2013-10-23 10:17:40

    实用好文~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号