修复SQLite-database disk image is malformed
运行某些SQL语句出错database disk image is malformed 说明SQLite的内部数据格式,已经损坏 sqlite> PRAGMA integrity_check; *** in database main *** Main freelist: 3 of 3 pages missing from overflow list starting at 0 排除磁盘空间不够的原因 另一种更快的修复方法 $echo “.dump” | sqlite3 old.db | sqlite3 new.db 直接将 old.db 修复为 new.db 或者 sqlite3 newsfeed.db .dump > newsfeed.sql sqlite3 newsfeed.db < newsfeed.sql 请参考 http://www.sqlite.org/faq.html#q21 http://www.sqlite.org/sqlite.html PHP使用popen调用sqlite shell来实现修复 $handle = popen(“mv ../backup.sqlite bad.sqlite && sqlite3 bad.sqlite .dump | sqlite3 good.sqlite && mv good.sqlite ../backup.sqlite”,‘r’);
压缩 sqlite3 my.sqlite 'VACUUM;' 原文:http://www.cnblogs.com/adinet/archive/2011/11/03/2233858.html (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |