Android 数据库文件 db 的备份和重载

最近应客户需求在 android TV 平台加酒店模式功能,其中有数据 Backup && Load 的功能,主要是把重要的电视参数备份到U 盘中,再在另一台电视中 用 Load 功能还原这些数据,已达到和前一台电视同样的设置。

起初copy的 *.db 文件,当load后,看菜单数据是正确的,但是关机再开机后,发现菜单显示又不是刚才load的数据,而是在load前调整的数据,代码里加log查看,没有发现哪里有问题,实在是头大,最后瞅到有 db-journal文件,例如 factory.db 伴随有 factory.db-journal,就去百度了db-journal文件,查到下面一段的解释,看了之后恍然大悟,db-journal 也要copy,问题得以解决,经验写出来分享给有需要的朋友

数据库为了更好实现数据的安全性,一半都会有一个Log文件方便数据库出现意外时进行恢复操作等。Sqlite虽然是一个单文件数据库,但麻雀虽小五脏俱全,它也会有相应的安全机制存在

这个journal文件便是Sqlite的一个临时的日志文件,主要用于sqlite事务回滚机制,在事务开始时产生, 在事务结束时删除。当程序发生崩溃或者系统断电时该文件将留在磁盘上,以便下次程序运行时进行事务回滚。

在android模式下,journal文件是永久的留在磁盘上不会被自动清除的。如果没有发生事务回滚那么.db-journal文件的大小为0,这样就避免了每次生成和删除journal文件的开销。

所以,在进行数据备份时最好同时备份两个文件比较安全。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值