zoukankan      html  css  js  c++  java
  • 普通文件和数据库存储的对比

    在大多数企业开发或Web开发中,都会涉及数据的存储和检索。存储数据有两种基本的方法:保存到普通文件中(File System),或者保存到数据库(Database)中。

     

    文件存储常见,并且简单,操作系统提供的完善的API,所以在早期项目中都会使用文件作存储载体。但是随着企业业务越来越复杂,网站访问量也越来越大时,对数据的并发性和检索速度有更高的要求。所以慢慢的也就引入使用数据库作为数据存储了。

     

    使用普通文件的遇到的问题:

    1. 当文件变大时,使用普通文件将会变得非常慢,访问速度制约了应用性能
    2. 在一个普通文件中查找特定的一个或一组记录将非常困难。
    3. 处理并发访问可能遇到问题。虽然可以使用锁定文件来操作文件,但是多个脚本访问文件时可能导致竞争条件的发生,它可能导致应用出现性能的瓶颈。
    4. 普通文件在顺序访问时具有优势,但是在随机访问数据时可能非常困难。除非你将整个文件读入到内存中,在内存中修改它,然后将整个文件写回去
    5. 除了使用文件访问权限作为限制外,还没有一个简单高效的方法区分不同级别的数据访问权限机制。

    关系数据库关系系统如何解决文件存储晕倒的问题:

    1. 提供了比普通文件更快的访问速度。
    2. 可以很容易查找并检索满足特定条件的数据集合
    3. 具有内置的处理并发访问机制。作为一个编程人员,不需要处理这些内容。
    4. 可以随机访问数据
    5. 具有内置的权限系统,有灵活的角色和权限管理功能。

     

    如果要创建一个简单的系统或者应用,而又觉得不需要一个功能全面的数据库系统时,我们可以使用SQLite。使用SQLite来作为一个中间人,一方面操作起来像普通文件一样方便和快捷,另一方面提供了数据库具有基本事务处理能力,和操作文件提供了一个基本的SQL接口。当然SQLite更多是作为应用或产品的嵌入式数据库,最主要是它开源的。

     

    本文基于 知识共享许可协议 知识共享署名-非商业性使用-相同方式共享 3.0 中国大陆许可协议发布,欢迎转载,演绎,但是必须保留本文的署名liminjun88(包含链接http://www.cnblogs.com/liminjun88/),且不得用于商业目的。如您有任何疑问或者授权方面的协商,请与我联系

  • 相关阅读:
    JavaScript你所不知道的困惑(3)
    Android的代码都得自己一个个敲一遍吗?
    现代化农业在美国的兴起与发展
    高内聚与低耦合实现小记
    iOS 载入图片选择imageNamed 方法还是 imageWithContentsOfFile?
    swift笔记——环境搭建及Hello,Swift!
    HDU 4832(DP+计数问题)
    [TJOI2019]甲苯先生的线段树
    2019-8-31-C#-如何写-DEBUG-输出
    2019-8-31-C#-如何写-DEBUG-输出
  • 原文地址:https://www.cnblogs.com/liminjun88/p/2532341.html
Copyright © 2011-2022 走看看