sqlite3数据库文件损坏修复

现象:输出提示信息 "SQLITE_CORRUPT[11]: database disk image is malformed"

原因:在生产环境下,突然意外断电导致数据库文件损坏,程序启动时去操作数据库提示上面现象。

解决:下面是我现有生产环境下的sqlite3数据库恢复过程。

  1. 备份生产环境的sqlite3数据库文件。

  2. 将原数据库文件删除,重新运行程序生成sqlite3数据库文件(或者自己手动创建一个空的数据库文件,但你需要知道原始数据库文件的结构格式啥的)。

  3. SQLite Expert Professional工具打开数据库,如下操作:

总结:最终程序正常运行,再无错误输出,并且访问的数据都正常,说明成功解决。

思考:实际上并不是数据结构和数据损坏,而是数据库文件本身损坏了,具体是哪里损坏?如何预防这种损坏现象?在程序里面是否可以做到这种预防,或者能否进行程序修复?有待研究。。。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值