在大多数企业开发或Web开发中,都会涉及数据的存储和检索。存储数据有两种基本的方法:保存到普通文件中(File System),或者保存到数据库(Database)中。
文件存储常见,并且简单,操作系统提供的完善的API,所以在早期项目中都会使用文件作存储载体。但是随着企业业务越来越复杂,网站访问量也越来越大时,对数据的并发性和检索速度有更高的要求。所以慢慢的也就引入使用数据库作为数据存储了。
使用普通文件的遇到的问题:
- 当文件变大时,使用普通文件将会变得非常慢,访问速度制约了应用性能
- 在一个普通文件中查找特定的一个或一组记录将非常困难。
- 处理并发访问可能遇到问题。虽然可以使用锁定文件来操作文件,但是多个脚本访问文件时可能导致竞争条件的发生,它可能导致应用出现性能的瓶颈。
- 普通文件在顺序访问时具有优势,但是在随机访问数据时可能非常困难。除非你将整个文件读入到内存中,在内存中修改它,然后将整个文件写回去
- 除了使用文件访问权限作为限制外,还没有一个简单高效的方法区分不同级别的数据访问权限机制。
关系数据库关系系统如何解决文件存储晕倒的问题:
- 提供了比普通文件更快的访问速度。
- 可以很容易查找并检索满足特定条件的数据集合
- 具有内置的处理并发访问机制。作为一个编程人员,不需要处理这些内容。
- 可以随机访问数据
- 具有内置的权限系统,有灵活的角色和权限管理功能。
如果要创建一个简单的系统或者应用,而又觉得 不需要一个功能全面的数据库系统时,我们可以使用SQLite。使用SQLite来作为一个中间人,一方面操作起来像普通文件一样方便和快捷,另一方面提 供了数据库具有基本事务处理能力,和操作文件提供了一个基本的SQL接口。当然SQLite更多是作为应用或产品的嵌入式数据库,最主要是它开源的。