iOS持久化存储-Realm

2022-12-06  本文已影响0人  马威明

什么是持久化存储?
1. 持久化存储,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问保存的数据
什么是沙盒机制?
1. iOS程序在安装的,系统会创建属于自己的沙盒文件,默认情况下只能访问程序自己的目录,这个目录被称为沙盒
2. 如何共享沙盒数据
a. App group
b. keychain group
iOS持久化方案
1. 文件存储 NSFileManager
2. plist文件
a. 将某些特定类,通过xml文件方式存储在目录中,支持序列化的类(NSArray;NSMutableArray;NSDictionary;NSMutableDictionary;NSData;NSMutableData;NSString;NSMutableString;NSNumber;NSDate)
3. preference(NSUserDefaults)
4. NSKeyedArchiver(归档),遵循协议和设置属性
实现协议方法
5. CoreData 是系统提供的本地持久化框架(面向对象开发管理,不关心传统的表数据库方法)
6. SQLite 是一款轻型的跨平台开源数据库,它实现了无配置,无服务要求的事务数据库引擎。SQLite可以在Mac OS-X, iOS, Android, Linux, 和 Windows上使用.常用的三房框架:
i. FMDB 在sqlite上做封装
b. Realm 是一款较新的面向对象,轻量级,高性能跨平台数据库,官网发布时间2014,支持各主流语言 Java OC Swift ReactNative


12fe3a3c17c147c9be2610b0e660b08b0843.png

i. 优点
1. 跨平台:现在很多应用都是要兼顾iOS和Android两个平台同时开发。如果两个平台都能使用相同的数据库,那就不用考虑内部数据的架构不同,使用Realm提供的API,可以使数据持久化层在两个平台上无差异化的转换
2. 简单易用:Realm的处理速度上比CoreData、SQLite更快,相对于CoreData和SQLite来说更容易上手
3. 可视化:Realm 还提供了一个轻量级的数据库查看工具,在Mac Appstore 可以下载“Realm Browser”这个工具,开发者可以查看数据库当中的内容,执行简单的插入和删除数据的操作。

  1. 接入 文档(https://realm.io/cn/docs/objc/latest/
    1. 创建数据模型 (类似于建表),继承RLMObject
      1. image
  2. 数模里面包含另一个Model 正常设置 即可
  3. image

    a. 模型包含数组

  4. 需在TestModel3泛型类型RLM_ARRAY_TYPE(TestModel3)
    1. image
      1. 数据库配置类 RLMRealmConfiguration
  5. 配置项
  6. 配置Realm存储路径
    1. 数据迁移
      1. 通过设置 RLMRealmConfiguration.schemaVersion 以及 RLMRealmConfiguration.migrationBlock 可以定义本地迁移
        1. 压缩空间, Realm的文件尺寸总是比存储在其中的数据总量要大,例如:存储1M数据会预留10M的空间 回调设置 shouldCompactOnLaunch
  7. 应用配置
  8. [RLMRealm realmWithConfiguration:config error:&err]
    1. [RLMRealmConfiguration setDefaultConfiguration:config] 设置默认
      1. 数据库操作 增 删 改 查
  9. 新增 两种方式 效果一样 内部代码一直的都是 begin commit
  10. image
  11. 删除全部 , 已删除对象不可使用了
  12. image
  13. 删除某个index 首选查询出数据后删除
  14. image
  15. 修改 注意点修改时一定要在事务(begin commit)中修改
  16. image
    1. image
  17. 查询全部
  18. image
  19. 条件查询 查询test字段 等于xxx的所有数据 ,Realm 支持大多数常见NSPredicate =, !=, >, <, >=, <=, BETWEEN 等,具体使用时可查看文档
  20. image
  21. 排序 通过 timestamp字段 ascending=yes 升序排序
  22. image
    1. 数据库升级 数据结构变更
  23. 修改version大于当前version
    1. 2.实现migrationBlock 具体业务 在block中实现
      1. 3.升级后数据变更
        1. 字段未调整的字段数据保留 ,已删除字段数据清空,总条数保留
          1. image
上一篇下一篇

猜你喜欢

热点阅读