加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

sqlite3 journal

发布时间:2020-12-12 19:40:27 所属栏目:百科 来源:网络整理
导读:sqlite3默认会开启journal,为了进行rollback。但是在突然断电的情况下,journal文件很容易就损坏了。 目前还没有发现数据库文件本身被损坏的情况。 一旦journal文件损坏,就没法打开数据库文件了。但是可以把journal机制关闭。 一旦journal文件损坏,还会造

sqlite3默认会开启journal,为了进行rollback。但是在突然断电的情况下,journal文件很容易就损坏了。

目前还没有发现数据库文件本身被损坏的情况。

一旦journal文件损坏,就没法打开数据库文件了。但是可以把journal机制关闭。

一旦journal文件损坏,还会造成文件系统损坏,journal文件都无法删除掉。

对journal文件所在目录进行ls的时候,会显示如下信息:

ls: ./数据库名字-journal : Input/Output error


出现这种情况,只能使用e2fsck命令进行修复了,命令如下:

先umount 分区

e2fsck -y /dev/设备文件


使用sqlite3_exec执行"PRAGMA journal_mode = OFF;"即可关闭journal文件


关闭journal文件后就不能使用事务机制了,否则,操作会报错。

cannot commit - no transaction is active

所以如果要关闭journal,最好将关闭journal的操作放到所以操作之前,也就是打开数据库之后立即关闭。


经测试,发现关闭journal后,突然断电,数据库文件总是消失,不知道为什么。最后找到一个办法,

在打开数据库后,立即执行,system("sync"),就没问题了。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读