修复SQLite-database disk image is malformed
2014-11-07 15:25
417 查看
转自:http://www.cnblogs.com/adinet/archive/2011/11/03/2233858.html
修复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
排除磁盘空间不够的原因
修复步骤
$ 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://zhiwei.li/text/2010/08/%e4%bf%ae%e5%a4%8dsqlite-database-disk-image-is-malformed/
修复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
排除磁盘空间不够的原因
修复步骤
$ 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://zhiwei.li/text/2010/08/%e4%bf%ae%e5%a4%8dsqlite-database-disk-image-is-malformed/
相关文章推荐
- 修复SQLite-database disk image is malformed
- sqlite 修复 database disk image is malformed 问题
- Sqlite修复方法(database disk image is malformed)
- [转]svn: E200030: sqlite[S11]: database disk image is malformed
- sqlite or svn 错误 The database disk image is malformed 可解决
- SQLite-database disk image is malformed问题的解决
- sqlite错误 database disk image is malformed 可解决
- Android.database.sqlite.SQLiteDatabaseCorruptException: database disk image is malformed
- SVN 报错 sqlite[S11]: database disk image is malformed
- sqlite错误 The database disk image is malformed database disk image is malformed 可解决
- SVN 报错 sqlite[S11]: database disk image is malformed
- svn sqlite[S11]: database disk image is malformed 终极解决方案
- sqlite关于The database disk image is malformed问题的解决
- svn: E200030: sqlite[S11]: database disk image is malformed
- SQLite 损坏 database disk image is malformed
- sqlite错误 The database disk image is malformed database disk image is malformed 可解决
- SVN 报错 sqlite[S11]: database disk image is malformed
- svn cleanup: sqlite: database disk image is malformed 解决方法
- sqlite错误 The database disk image is malformed database disk image is malformed 可解决
- SQLite出现database disk image is malformed(11)的处理