sqlite异常掉电相关问题(1)

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"),就没问题了。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值