来自WCDB的SQLite修复工具,感谢WCDB这个优秀的开源库。
- 把
RepairKit
文件夹拖入你的工程 - 在
Build Settings
的Other Linker Flags
中加入,-ObjC
/-force_load
/./RepairKit路径/sqlcipher.framework/sqlcipher
这三项。 - 在需要调用的类中
#import "WCRepairKitManage.h"
传入数据库路径即可完成备份。
[[WCRepairKitManage shareManage] backupDBPath:repairDBPath];
在有备份的情况,修复工具才可以生效。在数据库内的数据发生变化时,元数据备份有可能会过期。因此建议在子线程定期对其备份。
元数据通常只有几 kb 大小,且属于读操作,可以与其他操作并发执行。因此备份不会对性能产生大的影响。
传入数据库路径即可完成备份。
[[WCRepairKitManage shareManage] recoveryDBPath:repairDBPath DBPageSize:4096];
它将尝试从已损坏的数据库中读出数据,并插入到新数据库中。
修复过程根据数据库的大小不同,需要一定的时间。建议在界面上提示等待,并在子线程进行修复。
对于可再生的数据,如可从服务端重新拉取的数据,直接将数据库删掉重建是更好的恢复手段。
传入数据库路径和秘钥字符串即可完成加密备份。
[[WCRepairKitManage shareManage] backupDBPath:repairDBPath backupCipher:backupCipherStr];
解密恢复类似,只需多传入秘钥字符串即可。
[[WCRepairKitManage shareManage] recoveryDBPath:repairDBPath DBPageSize:4096 backupCipher:backupCipher];
RepairKit来自WCDB,因不属于对外接口,所以我通过参考Sample内的实现,完成了这个Demo。
微信移动端数据库组件WCDB系列(二) — 数据库修复三板斧
有任何的疑问和问题直接开启一个Issues
。
其他沟通事项可以给我发邮件[email protected]。