How to recover a corrupt SQLite3 database?(如何恢复损坏的 SQLite3 数据库?)
问题描述
这是之前回答的帖子的后续问题:是否有用于在 Linux 中验证 SQLite 数据库的命令行实用程序?
This is a follow up question to a previously answered post: Is there a command line utility for validating SQLite databases in Linux?
如果数据库产生以下错误:
If a database is producing the following error:
$ sqlite3 mydata.db "PRAGMA integrity_check"
Error: database disk image is malformed
是否有任何清理处理可以将数据库恢复到可用状态?即使可能会丢失一些损坏的记录?
Is there any cleanup processing that can be done to recover the database to a usable state? Even at the potential loss of some corrupt records?
谢谢
推荐答案
UPDATE:现在有一个自动方法内置于 SQLite:.recover
UPDATE: There is now an automatic method that is built into SQLite: .recover
有时,损坏仅或大部分出现在索引中,在这种情况下,通过尝试使用 .dump
转储整个数据库,可以获取部分或大部分记录,并使用这些命令来创建一个新的数据库:
Sometimes, the corruption is only or mostly in indexes, in which case it would be possible to get some or most records by trying to dump the entire database with .dump
, and use those commands to create a new database:
$ sqlite3 mydata.db ".dump" | sqlite3 new.db
然而,这并不总是可行的.
However, this is not always possible.
最简单、最可靠的方法是从备份中恢复数据库文件.
The easiest and most reliable way is to restore the database file from the backup.
这篇关于如何恢复损坏的 SQLite3 数据库?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何恢复损坏的 SQLite3 数据库?


- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- 更改自动增量起始编号? 2021-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- SQL 临时表问题 2022-01-01
- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01