美文网首页
Sqlite 数据库损坏的恢复

Sqlite 数据库损坏的恢复

作者: 沐左 | 来源:发表于2019-04-21 10:42 被阅读0次

    损坏原因: 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
    

    相关文章

      网友评论

          本文标题:Sqlite 数据库损坏的恢复

          本文链接:https://www.haomeiwen.com/subject/swfayqtx.html