现象:输出提示信息 "SQLITE_CORRUPT[11]: database disk image is malformed"
原因:在生产环境下,突然意外断电导致数据库文件损坏,程序启动时去操作数据库提示上面现象。
解决:下面是我现有生产环境下的sqlite3数据库恢复过程。
-
备份生产环境的sqlite3数据库文件。
-
将原数据库文件删除,重新运行程序生成sqlite3数据库文件(或者自己手动创建一个空的数据库文件,但你需要知道原始数据库文件的结构格式啥的)。
-
在SQLite Expert Professional工具打开数据库,如下操作:
总结:最终程序正常运行,再无错误输出,并且访问的数据都正常,说明成功解决。
思考:实际上并不是数据结构和数据损坏,而是数据库文件本身损坏了,具体是哪里损坏?如何预防这种损坏现象?在程序里面是否可以做到这种预防,或者能否进行程序修复?有待研究。。。