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

最近看到了这个颇有意思的问题,之前也没有思考过。若是有人问,究竟是在代码中跟IO文件交换速度快,仍是跟数据库交换速度快呢?数据库

 

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

 

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

 

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

 

因此,若是是简单的配置参数或者说特别小的数据,能够考虑存储在文件中,速度快。可是若是大批量的数据,确定是存在数据库中。通常也没有人选择存在文本文件中吧。spa

 

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