CN109828865A - 数据恢复方法、装置及电子设备 - Google Patents

数据恢复方法、装置及电子设备 Download PDF

Info

Publication number
CN109828865A
CN109828865A CN201910068356.1A CN201910068356A CN109828865A CN 109828865 A CN109828865 A CN 109828865A CN 201910068356 A CN201910068356 A CN 201910068356A CN 109828865 A CN109828865 A CN 109828865A
Authority
CN
China
Prior art keywords
database
data
damaged
backup data
backup
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201910068356.1A
Other languages
English (en)
Inventor
许圣霖
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Sankuai Online Technology Co Ltd
Original Assignee
Beijing Sankuai Online Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Sankuai Online Technology Co Ltd filed Critical Beijing Sankuai Online Technology Co Ltd
Priority to CN201910068356.1A priority Critical patent/CN109828865A/zh
Publication of CN109828865A publication Critical patent/CN109828865A/zh
Pending legal-status Critical Current

Links

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本申请提供一种数据恢复方法、装置及电子设备,所述方法的一具体实施方式包括:若确定第一数据库已损坏,获取预先针对所述第一数据库而存储的备份数据,所述备份数据包括所述第一数据库对应的表头数据;基于所述备份数据从已损坏的所述第一数据库中提取目标数据;基于所述目标数据确定第二数据库,所述第二数据库用于恢复已损坏的所述第一数据库。该实施方式实现了数据的恢复,无需依赖网络,解决了数据库的备份与数据恢复受网络限制的问题。

Description

数据恢复方法、装置及电子设备
技术领域
本申请涉及数据库技术领域,特别涉及一种数据恢复方法、装置及电子设备。
背景技术
SQLite数据库是一款轻型的开源嵌入式数据库,目前来说,SQLite数据库广泛地应用在各种终端设备中。SQLite数据库在使用过程中可能会发生损坏,而导致整个数据库记录的大量数据的丢失。在相关技术中,一般是将SQLite数据库上传至云端进行备份,当终端设备中的SQLite数据库发生损坏后,可以从云端下载已备份的数据库。但是,这种方式过于依赖网络,当终端设备无法连接网络时,无法进行数据库的上传和下载,从而使得数据库的备份与数据恢复受到了网络的限制。
发明内容
为了解决上述技术问题之一,本申请提供一种数据恢复方法、装置及电子设备。
根据本申请实施例的第一方面,提供一种数据恢复方法,包括:
若确定第一数据库已损坏,获取预先针对所述第一数据库而存储的备份数据,所述备份数据包括所述第一数据库对应的表头数据;
基于所述备份数据从已损坏的所述第一数据库中提取目标数据;
基于所述目标数据确定第二数据库,所述第二数据库用于恢复已损坏的所述第一数据库。
可选的,所述基于所述备份数据从已损坏的所述第一数据库中提取目标数据,包括:
基于所述备份数据解析已损坏的所述第一数据库中的B树结构;
从已损坏的所述第一数据库中提取B树结构的节点数据作为目标数据。
可选的,所述基于所述目标数据确定第二数据库,包括:
新建数据库文件;
采用所述备份数据在所述数据库文件中构建系统表;
采用所述目标数据生成用于插入节点数据的SQL语句;
按照所述SQL语句向所述数据库文件中插入节点数据,得到第二数据库。
可选的,所述方法还包括:
响应于完成所述第一数据库的创建,从所述第一数据库的系统表中提取所述第一数据库对应的表头数据作为所述备份数据;
对所述备份数据进行压缩存储。
可选的,所述方法还包括:
响应于确定所述第一数据库对应的表头数据发生变化,更新所述备份数据。
可选的,所述更新所述备份数据,包括:
将当前所述第一数据库的表头数据与所述备份数据进行比较,得到差异数据;
采用所述差异数据更新已存储的所述备份数据。
根据本申请实施例的第二方面,提供一种数据恢复装置,包括:
获取模块,用于在确定第一数据库已损坏时,获取预先针对所述第一数据库而存储的备份数据,所述备份数据包括所述第一数据库对应的表头数据;
第一提取模块,用于基于所述备份数据从已损坏的所述第一数据库中提取目标数据;
确定模块,用于基于所述目标数据确定第二数据库,所述第二数据库用于恢复已损坏的所述第一数据库。
可选的,所述装置还包括:
第二提取模块,用于响应于完成所述第一数据库的创建,从所述第一数据库的系统表中提取所述第一数据库对应的表头数据作为所述备份数据;
存储模块,用于对所述备份数据进行压缩存储。
根据本申请实施例的第三方面,提供一种计算机可读存储介质,所述存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述第一方面中任一项所述的方法。
根据本申请实施例的第四方面,提供一种电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现上述第一方面中任一项所述的方法。
本申请的实施例提供的技术方案可以包括以下有益效果:
本申请的实施例提供的数据恢复方法和装置,通过在确定第一数据库已损坏后,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据,基于上述备份数据从已损坏的第一数据库中提取目标数据,基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。本实施例由于预先存储了第一数据库对应的表头数据作为备份数据,当第一数据库由于部分数据出错而无法被访问时,能够取出备份数据,并基于该备份数据从已损坏的第一数据库中提取正常可用的目标数据,并采用目标数据创建能够被访问的第二数据库,用第二数据库恢复已损坏的第一数据库。从而实现了数据的恢复,无需依赖网络,解决了数据库的备份与数据恢复受网络限制的问题。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本申请。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。
图1是本申请根据一示例性实施例示出的一种数据恢复方法的流程图;
图2是本申请根据一示例性实施例示出的另一种数据恢复方法的流程图;
图3是本申请根据一示例性实施例示出的另一种数据恢复方法的流程图;
图4是本申请根据一示例性实施例示出的一种数据恢复装置的框图;
图5是本申请根据一示例性实施例示出的另一种数据恢复装置的框图;
图6是本申请根据一示例性实施例示出的另一种数据恢复装置的框图;
图7是本申请根据一示例性实施例示出的另一种数据恢复装置的框图;
图8是本申请根据一示例性实施例示出的另一种数据恢复装置的框图;
图9是本申请根据一示例性实施例示出的另一种数据恢复装置的框图;
图10是本申请根据一示例性实施例示出的一种电子设备的结构示意图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的装置和方法的例子。
在本申请使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本申请。在本申请和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包含一个或多个相关联的列出项目的任何或所有可能组合。
应当理解,尽管在本申请可能采用术语第一、第二、第三等来描述各种信息,但这些信息不应限于这些术语。这些术语仅用来将同一类型的信息彼此区分开。例如,在不脱离本申请范围的情况下,第一信息也可以被称为第二信息,类似地,第二信息也可以被称为第一信息。取决于语境,如在此所使用的词语“如果”可以被解释成为“在……时”或“当……时”或“响应于确定”。
如图1所示,图1是根据一示例性实施例示出的一种数据恢复方法的流程图,该方法可以应用于终端设备中。在本实施例中,为了便于理解,结合能够安装第三方应用程序的终端设备来举例说明。本领域技术人员可以理解,该终端设备可以包括但不限于诸如智能手机的移动终端设备、智能穿戴式设备、平板电脑、个人数字助理等等。该方法包括以下步骤:
在步骤101中,若确定第一数据库已损坏,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据。
在本实施例中,第一数据库可以是任意应用在终端设备中的SQLite数据库,第一数据库可以有任意合理的用途及存储内容,本申请对第一数据库的具体用途以及具体存储内容方面不限定。
在本实施例中,第一数据库对应的表头数据可以包括第一数据库记录的多个表中,各个表的表头信息。其中,表的表头信息可以包括表的结构信息等。可以预先提取第一数据库对应的表头数据进行存储,得到备份数据。当终端设备访问第一数据库时,若确定第一数据库已损坏,则可以首先获取预先针对第一数据库而存储的备份数据。
在步骤102中,基于上述备份数据从已损坏的第一数据库中提取目标数据。
在本实施例中,第一数据库可能仅由于系统表出错或者部分表的数据丢失等问题而损坏,导致终端设备无法正常的访问第一数据库。实际上,损坏的第一数据库大部分数据正常可用。在获取预先针对第一数据库而存储的备份数据后,可以基于该备份数据,从已损坏的第一数据库中提取目标数据,该目标数据为正常可用的数据。
具体来说,可以通过如下方式基于上述备份数据从已损坏的第一数据库中提取目标数据:首先,基于备份数据解析已损坏的第一数据库中的B树结构,然后,提取已损坏的第一数据库中B树结构的节点数据作为目标数据。
在步骤103中,基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。
在本实施例中,第二数据库也可以是SQLite数据库,第二数据库可以用于数据恢复。可以根据第一数据库中正常可用的目标数据,创建第二数据库,使第二数据库能够被终端设备正常访问。
具体来说,可以通过如下方式基于该目标数据确定第二数据库:首先,新建一个新的数据库文件,可以采用备份数据在数据库文件中构建系统表。然后,参照备份数据中表的结构信息,采用目标数据生成用于插入节点数据的SQL(Structured Query Language,结构化查询语言)语句。并按照该SQL语句向上述新创建的数据库文件中插入节点数据,得到第二数据库。
在本实施例中,可以采用第二数据库覆盖已损坏的第一数据库,以完成数据的恢复。
本申请的上述实施例提供的数据恢复方法,通过在确定第一数据库已损坏后,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据,基于上述备份数据从已损坏的第一数据库中提取目标数据,基于该目标数据确定第二数据库,并用第二数据库用于恢复已损坏的第一数据库。本实施例由于预先存储了第一数据库对应的表头数据作为备份数据,当第一数据库由于部分数据出错而无法被访问时,能够取出备份数据,并基于该备份数据从已损坏的第一数据库中提取正常可用的目标数据,并采用目标数据创建能够被访问的第二数据库,用第二数据库覆盖已损坏的第一数据库。从而实现了数据的恢复,无需依赖网络,解决了数据库的备份与数据恢复受网络限制的问题。
如图2所示,图2根据一示例性实施例示出的另一种数据恢复方法的流程图,该实施例描述了基于备份数据从已损坏的第一数据库中提取目标数据的过程,该方法可以应用于终端设备中,包括以下步骤:
在步骤201中,若确定第一数据库已损坏,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据。
在步骤202中,基于该备份数据解析已损坏的第一数据库中的B树结构。
在步骤203中,从已损坏的第一数据库中提取B树结构的节点数据作为目标数据。
在本实施例中,第一数据库可能仅由于系统表出错或者部分表的数据丢失等问题而损坏,导致终端设备无法正常的访问第一数据库。实际上,损坏的第一数据库大部分数据正常可用。在获取预先针对第一数据库而存储的备份数据后,可以从已损坏的第一数据库中提取目标数据,该目标数据为正常可用的数据。
一般来说,SQLite数据库文件由多个多重B树构成,每个B树存储一个表的数据或索引,因此,SQLite数据库文件的每个表由B树的树形结构构成。在本实施例中,由于上述备份数据包括第一数据库记录的多个表中,各个表的结构信息等。所以,可以基于该备份数据,解析已损坏的第一数据库中的B树结构,并可以提取已损坏的第一数据库中B树结构的节点数据作为目标数据。
在步骤204中,基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。
在本实施例中,第二数据库也可以是SQLite数据库,第二数据库可以用于数据恢复。可以根据第一数据库中正常可用的目标数据,创建第二数据库,使第二数据库能够被终端设备正常访问。采用第二数据库覆盖已损坏的第一数据库,以完成数据的恢复。
需要说明的是,对于与图1实施例中相同的步骤,在上述图2实施例中不再进行赘述,相关内容可参见图1实施例。
本申请的上述实施例提供的数据恢复方法,通过在确定第一数据库已损坏后,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据,基于该备份数据解析已损坏的第一数据库中的B树结构,提取已损坏的第一数据库中B树结构的节点数据作为目标数据,基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。本实施例能够通过备份数据解析已损坏的第一数据库中的B树结构,并基于第一数据库中的B树结构,从已损坏的第一数据库中提前正常可用的节点数据作为目标数据。从而实现了数据的恢复,无需依赖网络,进一步解决数据库的备份与数据恢复受网络限制的问题。
如图3所示,图3根据一示例性实施例示出的另一种数据恢复方法的流程图,该实施例详细描述了针对第一数据库进行备份的过程,该方法可以应用于终端设备中,包括以下步骤:
在步骤301中,响应于完成第一数据库的创建,从第一数据库的系统表中提取第一数据库对应的表头数据作为备份数据。
在步骤302中,对备份数据进行压缩存储。
一般来说,数据库的系统表中存储有数据库中各个表的表头数据,因此,在完成第一数据库的创建后,可以从第一数据库的系统表中提取第一数据库对应的表头数据作为备份数据,对备份数据进行压缩存储。
在步骤303中,响应于确定第一数据库对应的表头数据发生变化,更新备份数据。
在本实施例中,当在第一数据库中创建新表或者表的结构发生变化时,第一数据库对应的表头数据也会发生变化。由于第一数据库对应的表头数据存储于第一数据库的系统表中,因此,可以实时监控第一数据库的系统表的变化,若监控到第一数据库对应的表头数据发生变化,则可以将当前第一数据库对应的表头数据与压缩存储的备份数据进行比较,从而得到差异数据。并采用该差异数据更新已存储的备份数据。
在步骤304中,若确定第一数据库已损坏,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据。
在步骤305中,基于上述备份数据从已损坏的第一数据库中提取目标数据。
在步骤306中,基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。
需要说明的是,对于与图1-图2实施例中相同的步骤,在上述图3实施例中不再进行赘述,相关内容可参见图1-图2实施例。
本申请的上述实施例提供的数据恢复方法,通过响应于完成第一数据库的创建,从第一数据库的系统表中提取第一数据库对应的表头数据作为备份数据,对备份数据进行压缩存储,响应于确定第一数据库对应的表头数据发生变化,更新备份数据。若确定第一数据库已损坏,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据,基于上述备份数据从已损坏的第一数据库中提取目标数据,基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。从而实现了数据的恢复,无需依赖网络,有助于解决了数据库的备份与数据恢复受网络限制的问题。
下面结合一个完整的应用实例,对本申请方案进行示意性说明。
应用场景可以为:终端设备M对数据库N进行数据恢复的过程。其中,数据库N为SQLite数据库。
具体来说,首先,终端设备M在创建数据库N之后,可以获取数据库N的系统表信息,从该系统表信息中提取数据库N对应的表头数据作为备份数据,并对备份数据进行压缩存储。
当在数据库N中创建新表或者数据库N中表的结构发生变化时,数据库N对应的表头数据也随之发生变化。由于数据库N对应的表头数据存储于数据库N的系统表中,因此,可以实时监控数据库N的系统表的变化,若监控到数据库N对应的表头数据发生变化,则可以将当前数据库N对应的表头数据与压缩存储的备份数据进行比较,从而得到差异数据。可以进一步采用该差异数据更新已存储的备份数据。
当数据库N损坏后,终端设备M无法访问数据库N,则可以确定数据库N已损坏。一方面,终端设备M可以取出压缩存储的备份数据进行解压,并基于备份数据解析已损坏的数据库N中的B树结构,从已损坏的数据库N中提取B树结构的节点数据作为目标数据,该目标数据为正常可用的数据。另一方面,终端设备M可以新建一个数据库文件,采用备份数据在该数据库文件中构建系统表。并采用目标数据生成用于插入节点数据的SQL语句。
接着,可以按照上述SQL语句向上述新建的数据库文件中插入节点数据,得到数据库S。由于数据库S为根据数据库N中正常可用的目标数据而创建数据库,数据库S能够被终端设备M正常访问。因此,用数据库S覆盖已损坏的数据库N,从而可以实现数据的恢复。
可见,应用上述方案,由于预先存储了数据库N对应的表头数据作为备份数据,当数据库N由于部分数据出错而无法被访问时,能够取出备份数据,并基于该备份数据从已损坏的数据库N中提取正常可用的目标数据,并采用目标数据创建能够被访问的数据库S,用数据库S覆盖已损坏的数据库N。从而实现了数据的恢复,无需依赖网络,解决了数据库的备份与数据恢复受网络限制的问题。
与前述数据恢复方法实施例相对应,本申请还提供了数据恢复装置的实施例。
如图4所示,图4是本申请根据一示例性实施例示出的一种数据恢复装置框图,该装置可以包括:获取模块401,第一提取模块402和确定模块403。
其中,获取模块401,用于在确定第一数据库已损坏时,获取预先针对第一数据库而存储的备份数据,该备份数据包括第一数据库对应的表头数据。
第一提取模块402,用于基于该备份数据从已损坏的第一数据库中提取目标数据。
确定模块403,用于基于该目标数据确定第二数据库,该第二数据库用于恢复已损坏的第一数据库。
如图5所示,图5是本申请根据一示例性实施例示出的另一种数据恢复装置框图,该实施例在前述图4所示实施例的基础上,第一提取模块402可以包括:解析子模块501和提取子模块502。
其中,解析子模块501,用于基于备份数据解析已损坏的第一数据库中的B树结构。
提取子模块502,用于从已损坏的第一数据库中提取B树结构的节点数据作为目标数据。
如图6所示,图6是本申请根据一示例性实施例示出的另一种数据恢复装置框图,该实施例在前述图4所示实施例的基础上,确定模块403可以包括:新建子模块601,构建子模块602,生成子模块603和插入子模块604。
其中,新建子模块601,用于新建数据库文件。
构建子模块602,用于采用备份数据在上述数据库文件中构建系统表。
生成子模块603,用于采用目标数据生成用于插入节点数据的SQL语句。
插入子模块604,用于按照该SQL语句向上述数据库文件中插入节点数据,得到第二数据库。
如图7所示,图7是本申请根据一示例性实施例示出的另一种数据恢复装置框图,该实施例在前述图4所示实施例的基础上,该装置还可以进一步包括:第二提取模块404和存储模块405。
其中,第二提取模块404,用于响应于完成第一数据库的创建,从第一数据库的系统表中提取第一数据库对应的表头数据作为备份数据。
存储模块405,用于对该备份数据进行压缩存储。
如图8所示,图8是本申请根据一示例性实施例示出的另一种数据恢复装置框图,该实施例在前述图7所示实施例的基础上,该装置还可以进一步包括:更新模块406。
其中,更新模块406,用于响应于确定第一数据库对应的表头数据发生变化,更新备份数据。
如图9所示,图9是本申请根据一示例性实施例示出的另一种数据恢复装置框图,该实施例在前述图8所示实施例的基础上,更新模块406可以包括:比较子模块901和更新子模块902。
其中,比较子模块901,用于将当前第一数据库的表头数据与备份数据进行比较,得到差异数据。
更新子模块902,用于采用差异数据更新已存储的备份数据。
应当理解,上述装置可以预先设置在终端设备中,也可以通过下载等方式而加载到终端设备中。上述装置中的相应模块可以与终端设备中的模块相互配合以实现数据恢复方案。
对于装置实施例而言,由于其基本对应于方法实施例,所以相关之处参见方法实施例的部分说明即可。以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本申请方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
本申请实施例还提供了一种计算机可读存储介质,该存储介质存储有计算机程序,计算机程序可用于执行上述图1至图3任一实施例提供的数据恢复方法。
对应于上述的数据恢复方法,本申请实施例还提出了图10所示的根据本申请的一示例性实施例的电子设备的示意结构图。请参考图10,在硬件层面,该电子设备包括处理器、内部总线、网络接口、内存以及非易失性存储器,当然还可能包括其他业务所需要的硬件。处理器从非易失性存储器中读取对应的计算机程序到内存中然后运行,在逻辑层面上形成数据恢复装置。当然,除了软件实现方式之外,本申请并不排除其他实现方式,比如逻辑器件抑或软硬件结合的方式等等,也就是说以下处理流程的执行主体并不限定于各个逻辑单元,也可以是硬件或逻辑器件。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本申请的其它实施方案。本申请旨在涵盖本申请的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本申请的一般性原理并包括本申请未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本申请的真正范围和精神由下面的权利要求指出。
应当理解的是,本申请并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本申请的范围仅由所附的权利要求来限制。

Claims (10)

1.一种数据恢复方法,其特征在于,所述方法包括:
若确定第一数据库已损坏,获取预先针对所述第一数据库而存储的备份数据,所述备份数据包括所述第一数据库对应的表头数据;
基于所述备份数据从已损坏的所述第一数据库中提取目标数据;
基于所述目标数据确定第二数据库,所述第二数据库用于恢复已损坏的所述第一数据库。
2.根据权利要求1所述的方法,其特征在于,所述基于所述备份数据从已损坏的所述第一数据库中提取目标数据,包括:
基于所述备份数据解析已损坏的所述第一数据库中的B树结构;
从已损坏的所述第一数据库中提取B树结构的节点数据作为目标数据。
3.根据权利要求1所述的方法,其特征在于,所述基于所述目标数据确定第二数据库,包括:
新建数据库文件;
采用所述备份数据在所述数据库文件中构建系统表;
采用所述目标数据生成用于插入节点数据的SQL语句;
按照所述SQL语句向所述数据库文件中插入节点数据,得到第二数据库。
4.根据权利要求1-3中任一所述的方法,其特征在于,所述方法还包括:
响应于完成所述第一数据库的创建,从所述第一数据库的系统表中提取所述第一数据库对应的表头数据作为所述备份数据;
对所述备份数据进行压缩存储。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
响应于确定所述第一数据库对应的表头数据发生变化,更新所述备份数据。
6.根据权利要求5所述的方法,其特征在于,所述更新所述备份数据,包括:
将当前所述第一数据库的表头数据与所述备份数据进行比较,得到差异数据;
采用所述差异数据更新已存储的所述备份数据。
7.一种数据恢复装置,其特征在于,所述装置包括:
获取模块,用于在确定第一数据库已损坏时,获取预先针对所述第一数据库而存储的备份数据,所述备份数据包括所述第一数据库对应的表头数据;
第一提取模块,用于基于所述备份数据从已损坏的所述第一数据库中提取目标数据;
确定模块,用于基于所述目标数据确定第二数据库,所述第二数据库用于恢复已损坏的所述第一数据库。
8.根据权利要求7所述的装置,其特征在于,所述装置还包括:
第二提取模块,用于响应于完成所述第一数据库的创建,从所述第一数据库的系统表中提取所述第一数据库对应的表头数据作为所述备份数据;
存储模块,用于对所述备份数据进行压缩存储。
9.一种计算机可读存储介质,其特征在于,所述存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述权利要求1-6中任一项所述的方法。
10.一种电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现上述权利要求1-6中任一项所述的方法。
CN201910068356.1A 2019-01-24 2019-01-24 数据恢复方法、装置及电子设备 Pending CN109828865A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910068356.1A CN109828865A (zh) 2019-01-24 2019-01-24 数据恢复方法、装置及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910068356.1A CN109828865A (zh) 2019-01-24 2019-01-24 数据恢复方法、装置及电子设备

Publications (1)

Publication Number Publication Date
CN109828865A true CN109828865A (zh) 2019-05-31

Family

ID=66862239

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910068356.1A Pending CN109828865A (zh) 2019-01-24 2019-01-24 数据恢复方法、装置及电子设备

Country Status (1)

Country Link
CN (1) CN109828865A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113127259A (zh) * 2019-12-30 2021-07-16 北京懿医云科技有限公司 数据部署方法、装置、设备及存储介质
EP4202687A4 (en) * 2020-09-16 2024-02-14 Huawei Tech Co Ltd DATABASE REPAIR METHOD AND ELECTRONIC DEVICE

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101008957A (zh) * 2006-01-24 2007-08-01 国际商业机器公司 用于从备份数据映像建立数据库的方法和系统
CN101120319A (zh) * 2004-12-30 2008-02-06 伊姆西公司 数据恢复系统和方法
US20110035359A1 (en) * 2009-08-07 2011-02-10 International Business Machines Corporation Database Backup and Restore with Integrated Index Reorganization
CN101989305A (zh) * 2010-11-09 2011-03-23 福州星网视易信息系统有限公司 数据增量备份方法和系统
CN105045676A (zh) * 2015-07-02 2015-11-11 四川效率源信息安全技术有限责任公司 基于SQLite数据库的丢失数据的恢复装置和方法
CN106445727A (zh) * 2015-08-07 2017-02-22 中国移动通信集团重庆有限公司 数据备份和恢复方法及系统
CN106844607A (zh) * 2017-01-16 2017-06-13 重庆邮电大学 一种适用于非整型主键与空闲块合并的SQLite数据恢复方法
CN107193871A (zh) * 2017-04-12 2017-09-22 腾讯科技(深圳)有限公司 数据库修复方法及装置
CN107402843A (zh) * 2017-06-19 2017-11-28 阿里巴巴集团控股有限公司 数据库损坏的恢复方法、装置和设备
CN108090095A (zh) * 2016-11-23 2018-05-29 北京国双科技有限公司 批量重建数据库的方法和装置

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101120319A (zh) * 2004-12-30 2008-02-06 伊姆西公司 数据恢复系统和方法
CN101008957A (zh) * 2006-01-24 2007-08-01 国际商业机器公司 用于从备份数据映像建立数据库的方法和系统
US20110035359A1 (en) * 2009-08-07 2011-02-10 International Business Machines Corporation Database Backup and Restore with Integrated Index Reorganization
CN101989305A (zh) * 2010-11-09 2011-03-23 福州星网视易信息系统有限公司 数据增量备份方法和系统
CN105045676A (zh) * 2015-07-02 2015-11-11 四川效率源信息安全技术有限责任公司 基于SQLite数据库的丢失数据的恢复装置和方法
CN106445727A (zh) * 2015-08-07 2017-02-22 中国移动通信集团重庆有限公司 数据备份和恢复方法及系统
CN108090095A (zh) * 2016-11-23 2018-05-29 北京国双科技有限公司 批量重建数据库的方法和装置
CN106844607A (zh) * 2017-01-16 2017-06-13 重庆邮电大学 一种适用于非整型主键与空闲块合并的SQLite数据恢复方法
CN107193871A (zh) * 2017-04-12 2017-09-22 腾讯科技(深圳)有限公司 数据库修复方法及装置
CN107402843A (zh) * 2017-06-19 2017-11-28 阿里巴巴集团控股有限公司 数据库损坏的恢复方法、装置和设备

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113127259A (zh) * 2019-12-30 2021-07-16 北京懿医云科技有限公司 数据部署方法、装置、设备及存储介质
CN113127259B (zh) * 2019-12-30 2024-03-12 北京懿医云科技有限公司 数据部署方法、装置、设备及存储介质
EP4202687A4 (en) * 2020-09-16 2024-02-14 Huawei Tech Co Ltd DATABASE REPAIR METHOD AND ELECTRONIC DEVICE

Similar Documents

Publication Publication Date Title
US11455217B2 (en) Transaction consistency query support for replicated data from recovery log to external data stores
US9372908B2 (en) Merging an out of synchronization indicator and a change recording indicator in response to a failure in consistency group formation
CN107220142B (zh) 执行数据恢复操作的方法及装置
US8583599B2 (en) Reducing data duplication in cloud storage
CN110309218B (zh) 一种数据交换系统和数据写入方法
WO2018095299A1 (zh) 一种时序数据管理方法、设备和装置
CN105205175B (zh) 分布式数据库集群的数据操作方法及系统
CN104584524A (zh) 聚合中介系统中的数据
CN104750755B (zh) 一种数据库主备切换后的数据回补方法及系统
CN109710185A (zh) 数据处理方法及装置
CN106155838B (zh) 一种数据库备份数据恢复方法及装置
CN109947729B (zh) 一种实时数据分析方法及装置
CN109144785A (zh) 用于备份数据的方法和装置
CN109828865A (zh) 数据恢复方法、装置及电子设备
CN108762982B (zh) 一种数据库恢复方法、装置及系统
CN108108479A (zh) 一种数据库连接检测方法、系统、设备及计算机介质
CN104714880B (zh) 日志数据传输方法、系统及日志服务器
CN111523921B (zh) 漏斗分析方法、分析设备、电子设备及可读存储介质
CN114003172B (zh) 存储容量校正方法、装置、计算机设备以及存储介质
CN110046172A (zh) 在线计算数据处理方法及系统
CN110895498A (zh) 数据存储方法及装置
CN108614838B (zh) 一种用户群索引处理方法、装置及系统
CN108241556A (zh) Hdfs中数据异地备份的方法及装置
CN106469086B (zh) 事件处理方法和装置
CN116909816B (zh) 数据库恢复方法和装置、存储介质及电子设备

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication

Application publication date: 20190531

RJ01 Rejection of invention patent application after publication