问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

读写数据库与读写文件哪个更快

发布网友 发布时间:2022-04-12 11:09

我来回答

2个回答

懂视网 时间:2022-04-12 15:31

读写文件与读写数据库的效率比较 说明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 '数据库查询结果:
'; 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='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;$i<$times;$i++) 50 51 { 52 53 $res=$dbcon->mydb_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;$i<$times;$i++) 68 69 { 70 71 $res=$dbcon->mydb_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<$times;$i++) 96 97 { 98 99 $content = fnGetContent('test.txt'); 100 101 } 102 103 echo 'file_get_contents直接读'.$times.'次时间:'.(fnGetMicroTime()-$begin).'
'; 104 105 //--------------------------------- 106 107 $begin=fnGetMicroTime(); 108 109 for($i=0;$i<$times;$i++) 110 111 { 112 113 $fname = 'test.txt'; 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('test.txt'); 128 129 } 130 131 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过程如何,最后都要到磁盘上去读这个“文件”(记录存储区等效),所以当然这一切的前提是只读内容,无关任何排序或查找操作。

热心网友 时间:2022-04-12 12:39

同等算法,应该是磁盘读取效率更高;因为数据库在读取的过程中,还是要读取磁盘
磁盘读写和数据库读写哪个效率更高

1、直接读文件相比数据库查询效率更胜一筹,而且文中还没算上连接和断开的时间。2、一次读取的内容越大,直接读文件的优势会越明显(读文件时间都是小幅增长,这跟文件存储的连续性和簇大小等有关系),这个结果恰恰跟书生预料的相反,说明MYSQL对更大文件读取可能又附加了某些操作(两次时间增长了近30...

数据库备份

数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整性和可恢复性,我们能够快速响应数据丢失或系统故障,保障企业数据资产的安全无忧。上海今至电子科技有限公司,是一家从事运维服务、系统集成和网络工程的专业公司。业务涵盖IT解决方案、网络工程、应用软件开发、系统集成、服务器虚拟化、桌面虚拟化、高性能运算、负载均衡、数据容灾备份、服务外包、IT运维等。我们的理念:诚...

对于硬件来说,php 频繁的读写文件好,还是读数据库好

如果你做的这个系统规模不大,数据应用不频繁,那么文件系统完全是可以接受的,但如果你的系统规模比较大,同时数据是频繁更新和变化的,那么读写数据库的效率肯定会比文件高很多。

php的,用数据库储存和读取数据快,还是用txt文件储、存读取数据快。不...

我觉得txt快 一般不使用txt的原因主要到不是安全问题 而是i/o问题 因为每次写入的时候会产生一个磁盘都写如果访问量比较大的网站 这个读写会变的更加厉害 磁盘一般寿命不是很长

php从服务器读取数据快还是从数据库读取数据快

网站,php是放在web服务器里的,一般数据是放在mysql等数据库里。读取存储数据库肯定比读写文件要快。而且更简单。

程序读写硬盘数据快还是读写数据库数据快呢

数据库不也在硬盘里吗?你把硬件和软件来比较了啊。这个问题不该出现的,如果要和硬盘比较,那当然是内存了啊。速度是内存快。

硬盘的写入与读取速度谁对系统运行速度影响大?

但在安装软件、需要频繁对数据库进行写入等应用运行时,写入速度的作用就开始凸显。另外,影响系统及软件运行速度的,更多是4K小文件级别的队列读写(小文件读写速度也直接关系到IOPS,即每秒读写操作数的大小),而非大文件持续读写。因此一款SSD,即使持续读写速度与机械硬盘相差无几,但实际的系统及...

硬盘的写入与读取速度谁对系统运行速度影响大?

然而,在需要频繁进行文件写入操作的情况下,比如安装软件或对数据库进行频繁写入时,写入速度的重要性开始显现。此时,写入速度对系统整体性能的影响更为明显。影响系统和软件运行速度的另一个重要因素是4K小文件级别的队列读写操作。小文件读写的效率直接影响到每秒读写操作数(IOPS)的大小,而IOPS是衡量...

将数据存入数据库好,还是存入xml文件好,还是各有优缺点?请各位指点...

各有优缺点,小量的数据可以用xml代替数据库,因为xml加载是加载在内存中,读写速度比数据库快得多,数据量较大那样就用数据库了,不然内存耗费太多。

磁盘读写和数据库读写哪个效率更高

同等算法,应该是磁盘读取效率更高;因为数据库在读取的过程中,还是要读取磁盘

文件和数据库的异同

如SQL语言,能够支持数据的查询、更新、删除、插入等操作,并具有数据一致性、安全性、恢复和并发控制等功能,而文件的数据操作和管理方式较为简单,通常只支持基本的读写操作。综上所述,文件和数据库在数据管理的多个方面存在差异,选择使用哪种方式取决于具体的应用场景和需求。

数据库读和写哪个快 net中读写数据库需要用到哪些类 数据库读写分离 中间件 sql数据库文件的后缀有哪些 数据库读写 数据库的读写分离怎么实现 数据库读写冲突 python 数据库 读写 效率 数据库读写分离的弊端
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
贵阳公积金需要哪些资料 现代著名散文大师 列举几个散文大师 越多越好 世界十大散文名家 ...x减3分之2x等于4分之3 6分之5x除以3等于8分之3 4除以(x加 X/4分之3=5分之4 X减8分之5X=3 3分之2X除以4分之1=12 快! winserver启动盘-(win 启动盘) 大学数学清华出版图书 OSEA视频认证从初级认证,我想升级到高级认证,是重新交会费认证吗? 视频认证的图片能更改吗 支付宝帐号和密码忘记了怎么办?,如果重新申请以前那个怎么办,有影响吗 铁板烧铁板用几毫米厚好用? 蒜台炒肉怎么炒才好吃 大蒜炒肉皮怎么做好吃 听说铁板烧在古代就有了,那古代用什么做铁板烧啊 用什么样的钢做铁板烧好?用着亮一些传热快一些?我用铁板做的可是烧烧板上面就变黑了?怎么才能不 湖南四维卫浴配套有限公司怎么样? 铁板烧用的是什么铁板,冷轧板还是热轧板,哪个更便宜? 我想知道外面路边的铁板烧,铁板鱿鱼用的铁板是什么铁板,是冷轧还是热轧。怎么区分。有毒吗?炒锅是用什 九牧卫浴好还是瑞士希箭牌好? 铁板烧烤的铁板用什么金属材料最好? 四维卫浴怎么样? 请问铁板烧要用什么材料做好点,是用不绣铁还是不绣钢,还是别的材料 vivo手机应用商店下载的东西怎么在桌面上不显示,只能在应用商店打开? 烧烤用什么铁板 四维卫浴的公司历史 雅思7分是什么水平,能否申请国外的好大学 日语专业,雅思7分可以申请英国的大学吗? 申请去英国留学时就要递交雅思成绩吗 欧派卫浴怎么样? 扶桑花的花期要怎样调控? 红桑扶桑花花期短怎么能够让它延长花期? 如何延长扶桑花开花期 网站读取 文本文档 和 数据库 那个效率高? 用一般户发工资会有什么后果 不小心用一般户发工资了怎么办,现在要怎么处理? 一般户可以代发工资吗 老师,一般户发工资会有怎样后果? 用一般户发工资的后果 一般账户(用来缴税)可以代发工资吗? 浦发银行一般户要代发工资怎么办 一般账户可以发工资么? 赞美“房地产”的成语有哪些? 形容房地产开盘很火爆的词汇有哪些比如千人抢房啊 求形容当前房地产行情的成语 帮忙找些跟房地产有关的词汇 谁有关于赞美房地产的快板词啊?几句也行。急用!!! 现代房地产经济有何特征,是属于萧条还是危机、饱和,或者竞争激烈,那个词语更能准确的形容呢? 赞美“公司”的词语有哪些? 关于房地产方面的一些名词解释