運行某些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
排除磁盤空間不夠的原因
修復步驟
$ sqlite3 backup.sqlite
sqlite> .output “_temp.tmp”
sqlite> .dump
sqlite> .quit
$ sqlite3 new.sqlite
sqlite> .read “_temp.tmp”
sqlite> .quit
就將錯誤的backup.sqlite修復爲new.sqlite了
另一種更快的修復方法
$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’);
$read = fread($handle, 4096);
echo $read;
pclose($handle);
壓縮
sqlite3 my.sqlite 'VACUUM;'
原文:http://www.cnblogs.com/adinet/archive/2011/11/03/2233858.html