关于数据库读取速度与文件IO读取速度的比较分析

最近看到了这个很有意思的问题,以前也没有思考过。如果有人问,到底是在代码中跟IO文件交换速度快,还是跟数据库交换速度快呢?

 

这个问题还是比较复杂的,数据库的存储数据方式要比单纯的文件存储复杂很多。其实,如果我们熟悉数据库的结构,那么很容易解决这个问题。简单的来讲,一个运行的数据库实例是由两部分组成的,SGA(说白了就是内存区域,包含各种运行参数以及缓存信息)与数据文件。

 

就一个简单的操作而言,如果我们只是insert一条语句,如果比较速度,那么当然是写入文件快,这只是一个简单的IO操作。此时写入数据库的话,首先需要建立连接,这个需要时间,其次要先在内存中SGA进行分析,解析SQL语句,再加上一些必要的操作,最后写入到数据库文件中,这个本质上也是一个文件。

 

但是,数据库的功能远远的大于文本文件,而且这两个概念是不能相比的。数据库的SGA缓存优化,能够大大减少搜索时间。而且文本文件只是一个简单的存储,没有检索功能。

 

所以,如果是简单的配置参数或者说特别小的数据,可以考虑存储在文件中,速度快。但是如果大批量的数据,肯定是存在数据库中。一般也没有人选择存在文本文件中吧。

 

http://blog.163.com/ruihuadesunny@126/blog/static/3902619120101018104335211/

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值