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文件的开销。

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

猜你喜欢

转载自blog.csdn.net/bingsfsg/article/details/103669486