1.数据持久化的方式
1.属性列表(plist存储)
用于存储在程序中不经常修改、数据量小的数据,不支持自定义对象存储,支持数据存储的类型为:Array,Dictionary,String,Number,Data,Date,Boolean,通常用来存放接口名、城市名、银行名称、表情名等极少修改的数据,plist文件是将某些特定的类,通过xml的方式保存在目录中。
2.偏好设置(NSUserDefaults)
用于存储用户的偏好设置,同样适合于存储轻量级的用户数据,数据会自动保存在沙盒的Library/Preferences目录下,本质上就是一个plist文件,所以同样的不支持自定义对象存储,支持数据存储的类型为:Array,Dictionary,String,Number,Data,Date,Boolean,可以用做检查版本是否更新、是否启动引导页、自动登录、版本号等等,需要注意的是NSUserDefaults是定时的将缓存中的数据写入磁盘,并不是即时写入,为了防止在写完NSUserDefaults后,程序退出导致数据的丢失,可以在写入数据后使用synchronize强制立即将数据写入磁盘。
3.归档序列化存储
归档可以直接将对象存储为文件,也可将文件直接解档为对象,相对于plist文件与偏好设置数据的存储更加多样,支持自定义的对象存储,归档后的文件是加密的,也更加的安全,文件存储的位置可以自定义。遵守NSCoding或者NSSecureCoding协议。
4.沙盒存储
可以提高程序的体验度,为用户节约数据流量,主要在用户阅读书籍、听音乐、看视频等,在沙盒中做数据的存储,主要包含文件夹: Document:最常用的目录,存放重要的数据,iTunes同步时会备份改目录Library/Caches:一般存放体积大,不重要的数据,iTunes同步时不会备份该目录Library/Preferences:存放用户的偏好设置,iTunes同步时会备份该目录tmp:用于存放临时文件,在程序未进行时可能会删除该文件夹中的数据,iTunes同步时不会备份该目录。
5.Core Data
Core Data是框架,并不是数据库,该框架提供了对象关系的映射功能,使得能够将OC对象转换成数据,将数据库中的数据还原成OC对象,在转换的过程中不需要编写任何的SQL语句,在Core Data中有三个重要的概念:
- 1.NSPersistentStoreCoordinator : 持续化存储协调器,在NSPersistentStoreCoordinator中包含了持久化存储区,在持久化存储区中包含了数据表中的很多数据,
- 2.持久化存储区的设置通常选择NSSQLiteStoreType,也就是选择SQLite数据库
- 3.NSManagedObjectModel:托管对象模型,用于描述数据结构的模型
6.SQLite3
SQLite是轻量级的数据库,占用资源很少,最初是用于嵌入式的系统,在iOS中使用SQLite,需要加入"libsqlite3.tbd"依赖库并导入头文件。不应该频繁的打开关闭数据库,有可能会影响性能,应在启动程序时打开数据库,在退出程序时关闭数据库
7.FMDB
FMDB以OC的方式封装了SQLite的C语言API,减去了冗余的C语言代码,使得API更具有OC的风格,更加的面向对象,相对于Core Data框架更加的轻量级,FMDB还提供了多线程安全的数据库操作方法,在FMDB中有三个重要的概念:
- FMDatabase:一个FMDatabase就代表一个SQLite数据库,执行sql语句
- FMResultSet:执行查询后的结果集
- FMDatabaseQueue:用于在多线程中执行多个查询或更新,安全的
2.数据库的优化
- FMDB事务批量更新数据库速度问题。
- 写同步(synchronous)
在SQLite中,数据库配置的参数都由编译指示(pragma)来实现的,而其中synchronous选项有三种可选状态,分别是full、normal、off
设置为synchronous OFF(0)时,SQLite在传递数据给系统以后直接继续而不暂停 - 一条SQL语句插入多条数据
- 在事务中进行插入处理
- 数据有序插入
3.事务
1.什么是事务?
- 作为单个逻辑工作单元执行的一系列操作,而这些逻辑工作单元需要具有原子性,一致性,隔离性和持久性
- 是并发控制的基本单元。所谓的事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单元。例如,银行转账工作:从一个账号扣款并使另一个账号增款,这两个操作要么都执行,要么都不执行。所以,应该把它们看成一个事务。
- 事务是一种机制,用于维护数据库的完整性。
2.事务基本特征
- 原子性:事务的各元素是不可分的,事务是一个完整的操作,一个操作序列,要么都执行,要么都不执行
- 一致性:事务完成时,数据必须是一致的,保证数据的无损
- 隔离性:多个事务彼此隔离,事务必须是独立的,任何事务都不应该受影响
- 持久性:事务完成之后,它对于系统的影响是永久的,该修改即使出现系统故障也将一直保留,真实的修改了数据库