Sqlite 数据库损坏的恢复

损坏原因: http://www.sqlite.org/lockingv3.html#how_to_corrupt

检查数据库损坏情况

首先sqlite3 database_name进入数据库
然后运行命令 PRAGMA integrity_check;
如果数据库文件损坏就会报损坏的错误,如何数据库文件是完好的就会显示OK。


SQlite database disk image is malformed

数据表的损坏,一般原因:
数据表在读写的时候,设备突然断电、关机、软件闪退等情况下会造成数据库或表的损坏。


Sqlite3 导出损坏包中的数据

客户的一张表中的数据丢失了,无法查看,一共35条附件数据



1、安装 Sqlite3

安装步骤,菜鸟教程

安装成功



2、使用Sqlite 命令导出数据为sql文件

  • dump 命令 导出为 sql 文件

使用如下命令:

sqlite3 old.db .dump > newsfeed.sql

cmd 打开命令行,定位到数据库文件夹,使用上述命令,dump 成sql


  • 用文本编辑器打开newsfeed.sql

把文件拉倒最后面,我们可以看到 ROLLBACK; -- due to errors

把ROLLBACK;改成COMMIT;


  • 用newsfeed.sql生成新的数据包

使用如下命令生成新的数据库包

sqlite3 new.db < newsfeed.sql

我们可以看到数据找回了31条


2、 加密结果库的数据找回

客户反馈软件导出成果时出错,经过对数据的排查发现是 WYHCFJ 这张表中的 数据有损坏。

用上面的相同的方法,

1、DB Browser 打开加密的数据库

2、导出数据库中的数据为sql文件


3、利用sqlit3 命令将 sql 文件重新生成db文件


4、打开重新生成的db ,发现附件表中有420条附件


最大ID是420,证明原库中是从421开始出错的

5、打开原始db,我们从422开始查询


可以看到从422开始,数据没有错误,那么应该就只有421这条数据是错误的,我们验证下

6、在原始db中查询421的数据


我们发现这条数据是错误的

7、怎么跳过错误的数据,而将421之后的数据插入到新的库中?

这里我联结了新旧两个数据库,然后使用INSERT INTO SELECT 语句

  • 利用DBMS联结新旧数据库

  • 利用SQL语句插入数据

insert into WYHCFJ
select * 
from hcjg00.WYHCFJ
where F_ID > 421
  • 插入数据成功

将数据放回软件,验证成功!问题解决,排除掉了421的异常数据


3、不可挽回的损坏

在数据恢复的时候,有时候会发现导出的 sql 文件的时候,会出现这样的情况 file is not a database
这种情况我就木鸡了.....

PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
/**** ERROR: (26) file is not a database *****/
ROLLBACK; -- due to errors

推荐阅读更多精彩内容