@H_502_1@sqlite3默认会开启journal,为了进行rollback。但是在突然断电的情况下,journal文件很容易就损坏了。
@H_502_1@目前还没有发现数据库文件本身被损坏的情况。
@H_502_1@一旦journal文件损坏,就没法打开数据库文件了。但是可以把journal机制关闭。
@H_502_1@一旦journal文件损坏,还会造成文件系统损坏,journal文件都无法删除掉。
@H_502_1@对journal文件所在目录进行ls的时候,会显示如下信息:
@H_502_1@ls: ./数据库名字-journal : Input/Output error
@H_502_1@
@H_502_1@出现这种情况,只能使用e2fsck命令进行修复了,命令如下:
@H_502_1@先umount 分区
@H_502_1@
@H_502_1@使用sqlite3_exec执行"PRAGMA journal_mode = OFF;"即可关闭journal文件
@H_502_1@
@H_502_1@关闭journal文件后就不能使用事务机制了,否则,操作会报错。
@H_502_1@cannot commit - no transaction is active
@H_502_1@所以如果要关闭journal,最好将关闭journal的操作放到所以操作之前,也就是打开数据库之后立即关闭。
@H_502_1@