CN102024040A - 数据库同步方法、装置和系统 - Google Patents
数据库同步方法、装置和系统 Download PDFInfo
- Publication number
- CN102024040A CN102024040A CN 201010578325 CN201010578325A CN102024040A CN 102024040 A CN102024040 A CN 102024040A CN 201010578325 CN201010578325 CN 201010578325 CN 201010578325 A CN201010578325 A CN 201010578325A CN 102024040 A CN102024040 A CN 102024040A
- Authority
- CN
- China
- Prior art keywords
- sign
- synchronous regime
- database
- new data
- embedded
- 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
Links
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明实施例公开一种数据库同步方法、装置和系统,涉及嵌入式系统领域,以解决现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。本发明提供的技术方案包括:在进行嵌入式数据库更新时,在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;在接收到后台服务器发送的同步请求时,将所述嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器。本发明实施例提供的数据库同步方法、装置和系统,能够应用于嵌入式系统的数据库同步中,如智能卡中嵌入式数据库的同步。
Description
技术领域
本发明涉及嵌入式系统领域,尤其涉及一种数据库同步方法、装置和系统。
背景技术
在嵌入式数据库发生变化后,用于备份该嵌入式数据库的备份数据库也需要相应的变化,此时需要通过嵌入式数据库同步系统实现嵌入式数据库与备份数据库之间的数据同步。现有的嵌入式数据库同步系统往往是把发生变化的数据从嵌入式数据库中提取出来,然后将变化的数据另外存储在同步数据库中。在接收到备份服务器发送的同步指令时,获取同步数据库中的数据,并将数据发送给备份服务器,备份服务器根据接收的数据同步备份数据库。例如,在智能卡与后台服务器之间实现数据同步时,在智能卡数据库中数据发生变化时,嵌入式数据库同步系统将变化的数据从智能卡数据库表中提取出来,并保存到智能卡中的同步数据库中,在接收到后台服务器发送的同步指令时,从同步表中获取相应的数据发送给后台服务器。其中,同步数据库中包括如表1所示的存储数据更新信息表、如表2所示的存储同步更新会话信息表以及如表3所示的存储服务器配置信息表。
表1存储数据更新信息(sync_record)表
表2存储同步更新会话信息(sync_latest_time)表
表3存储服务器配置信息(svnc_confieure)表
在实现本发明的过程中,发明人发现,现有技术的嵌入式数据库同步实现方式,如表1-3所示,首先需要在智能卡上建立额外的一个同步数据库以及上述三个数据库表;其次,每当智能卡数据库中插入、删除或更新一条记录,同步数据库中的表1和表2中都会相应插入一条记录。举例说明,在典型的32位系统,表1和表2的记录长度分别是15字节和9字节,也就是每插入一条记录,需要至少消耗额外24字节的空间,需要消耗大量额外存储空间,然而嵌入式系统中的非易失性存储资源非常有限。
发明内容
本发明实施例提供一种数据库同步方法、装置和系统,用于解决现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
为达到上述目的,本发明实施例采用如下技术方案:
一种数据库同步的方法,包括:在进行嵌入式数据库更新时,在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;在接收到后台服务器发送的同步请求时,将所述嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据以同步数据包的形式发送给所述后台服务器。
一种数据库同步的方法,包括:发送同步请求给客户端;接收所述客户端根据所述同步请求发送的同步数据包,所述同步数据包包括同步状态标识以及与所述同步状态标识对应的更新数据;根据所述同步状态标识对所述更新数据进行相应的操作。
一种数据库同步装置,包括:
更新单元,在进行嵌入式数据库更新时,用于在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;
同步单元,在接收到后台服务器发送的同步请求时,用于将更新单元更新得到的嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据以同步数据包的形式发送给所述后台服务器。
一种智能卡,包括上述的数据库同步装置。
一种后台服务器,包括:
发送单元,用于发送同步请求给客户端;
接收单元,用于接收所述客户端根据所述同步请求发送的同步数据包,所述同步数据包包括同步状态标识以及与所述同步状态标识对应的更新数据;
执行单元,用于根据所述接收单元接收的同步状态标识对所述接收单元接收的更新数据进行相应的操作。
一种数据库同步系统,包括:
客户端,
在进行嵌入式数据库更新时,用于在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;
在接收到后台服务器发送的同步请求时,用于将嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据以同步数据包的形式发送给所述后台服务器;
后台服务器,
用于发送同步请求给客户端;
用于接收所述客户端根据所述同步请求发送的同步数据包,所述同步数据包包括同步状态标识以及与所述同步状态标识对应的更新数据,根据所述同步状态标识对所述更新数据进行相应的操作。
本发明实施例提供的数据库同步方法、装置和系统,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,节约了宝贵的卡上存储资源,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
附图说明
图1为本发明实施例提供的数据库同步方法的流程图;
图2为本发明又一实施例提供的数据库同步方法的流程图;
图3为本发明另一实施例提供的数据库同步方法的流程图一;
图4为图3所示的数据库同步方法中步骤301的方法流程图;
图5为图3所示的数据库同步方法中步骤303的方法流程图;
图6为本发明另一实施例提供的数据库同步方法的流程图二;
图7为图3所示的数据库同步方法中步骤305的方法流程图;
图8为本发明实施例提供的数据库同步装置的结构示意图一;
图9为图8所示的数据库同步装置中更新单元的结构示意图;
图10为图8所示的数据库同步装置中同步单元的结构示意图;
图11为本发明实施例提供的数据库同步装置的结构示意图二;
图12为本发明实施例提供的后台服务器的结构示意图一;
图13为本图12所示的后台服务器中执行单元的结构示意图;
图14为本发明实施例提供的后台服务器的结构示意图二;
图15为本发明实施例提供的数据库同步系统的结构示意图。
具体实施方式
为了解决现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题,本发明实施例提供一种数据库同步方法、装置和系统。
如图1所示,本发明实施例提供的数据库同步方法,包括:
步骤101,在进行嵌入式数据库更新时,在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成。
在本实施例中,所述客户端在进行嵌入式数据库更新时,首先需要获取更新请求,所述更新请求包括更新数据和更新动作,所述更新动作可以是对嵌入式数据库中数据的删除、插入或修改。
步骤102,在接收到后台服务器发送的同步请求时,将所述嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器。
在本实施例中,可以将所述嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据以同步数据包的形式发送给所述后台服务器。
本发明实施例提供的数据库同步方法,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
如图2所示,本发明又一实施例提供的数据库同步方法,包括:
步骤201,发送同步请求给客户端。
在本实施例中,后台服务器可以周期性发送同步请求给所述客户端,也可以是人为触发所述后台服务器发送所述同步请求给所述客户端。
步骤202,接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据。
步骤203,根据所述同步状态标识对所述更新数据进行相应的操作。
本发明实施例提供的数据库同步方法,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
为了使本领域技术人员能够更清楚地理解本发明实施例提供的技术方案,下面通过具体的实施例,对本发明另一实施例提供的数据库同步方法进行详细说明。
如图3所示,本发明另一实施例提供的数据库同步方法,包括:
步骤301,在进行嵌入式数据库更新时,客户端在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成。
如图4所示,所述步骤301,包括:
步骤401,客户端接收应用程序发送的更新请求,所述更新请求包括更新动作和更新数据。
在本实施例中,在所述应用程序向嵌入式系统发送更新请求时,也向所述客户端发送该更新请求。所述更新动作包括三种动作类型,插入、删除和修改。在本实施例中,以插入动作作为具体实例进行详细说明。
所述更新请求包括更新数据和更新动作,所述更新数据如表4所示,所述更新动作为插入。
表4:需要插入的数据
学号 | 姓名 | 年龄 | 性别 | 系别 | 年级 |
991098 | 洪钧 | 20 | M | CS | 2 |
步骤402,所述客户端根据所述更新动作生成同步状态标识。
在本实施例中,由于所述更新动作包括三种动作类型,所述同步状态标识也包括三种标识类型,为同步插入标识、同步删除标识和同步修改标识。所述同步插入标识可以用INSERT表示,所述同步删除标识可以用DELETE表示。值得说明的是,修改动作可以等同于删除和插入两个动作先后完成实现的,所以修改可以由一对删除、插入动作表示,那么所述同步修改标识可以用一对INSERT和DELETE进行表示。
步骤403,所述客户端将所述更新数据以及所述同步状态标识相应的保存到嵌入式数据库中。
在本实施例中,在所述更新请求为插入表4所述的更新数据时,保存到所述嵌入式数据库中的更新数据以及对应的同步状态标识如表5所示。
表5:保存到嵌入式数据库中的数据
步骤302,后台服务器向所述客户端发送同步请求。
在本实施例中,所述后台服务器可以是周期性向所述客户端发送同步请求,其周期时长根据上述的应用程序的更新频率设置,所述后台服务器还可以在预先设置的需要进行数据库同步的时间点上向所述客户端发送同步请求,当然,所述后台服务器向所述客户端发送同步请求的方式并不仅限于上述两种,此处不一一赘述。
步骤303,所述客户端在接收到所述后台服务器发送的同步请求时,将嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器。
如图5所示,所述步骤303包括:
步骤501,所述客户端接收后台服务器发送的同步请求。
步骤502,在接收到所述同步请求时,所述客户端获取在嵌入式数据库更新时保存的同步状态标识以及与所述同步状态标识相对应的更新数据。
在本实施例中,可以获取到如表6所示的同步状态标识以及与所述同步状态标识相对应的更新数据。
如表6所示,同步状态标识以及与所述同步状态标识相对应的更新数据
步骤503,将所述同步状态标识以及与所述同步状态标识相对应的更新数据发送给后台服务器。
在本实施例中,所述同步状态标识以及与所述同步状态标识相对应的更新数据以同步数据包的形式发送给后台服务器。
优选的,为了后台服务器与客户端侧的嵌入式系统之间实现一对多的形式,所述同步数据包携带有嵌入式系统的标识,如图6所示,所述数据库同步方法,还包括:
步骤601,所述客户端在接收到后台服务器发送的同步请求时,将与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识发送给后台服务器。
在本实施例中,所述与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识可以携带在所述同步数据包中,与所述同步状态标识以及与所述同步状态标识相对应的更新数据一同发送给所述后台服务器。
所述后台服务器与客户端侧的嵌入式系统之间实现一对多的形式为:一个服务器对应多个客户端侧的嵌入式系统,所述嵌入式系统中包含多个嵌入式数据库。
举例说明,嵌入式系统为校园一卡通智能卡,所述校园一卡通智能卡可以包括学生信息数据库、图书借读数据库、卡内余额数据库等。那么,在进行校园一卡通智能卡中学生信息数据库库更新时,所述同步数据包,如表7所示,所述表7根据表6所述的更新数据得到。
表7:同步数据包
步骤304,所述后台服务器接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据。
在本实施例中,所述后台服务器接收所述客户端根据所述同步请求发送的同步数据包,所述同步数据包包括同步状态标识以及与所述同步状态标识对应的更新数据。
优选的,为了后台服务器与客户端侧的嵌入式系统之间实现一对多的形式,所述同步数据包携带有嵌入式系统的标识,如图6所示,所述数据库同步方法,还包括:
步骤602,所述后台服务器接收所述客户端根据所述同步请求发送的与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识。
在本实施例中,可以是,所述后台服务器接收所述客户端根据所述同步请求发送的同步数据包,所述同步数据包还包括与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识。如表7所示的系统的标识、数据库的标识。
在本实施例中,可以得到,所述后台服务器中的学生信息数据库需要进行一次修改两次插入,系统的标识为123489的学生信息数据库中实现了一次删除和一次插入,从而实现了修改的动作,而系统的标识为123444以及系统的标识为123445的学生信息数据库实现了插入动作。
步骤305,所述后台服务器根据所述同步状态标识对所述更新数据进行相应的操作。
如图7所示,所述步骤305包括:
步骤701,解析所述同步状态标识,得到与所述同步状态标识对应的更新动作,所述更新数据包括删除和/或插入;
步骤702,根据所述更新动作对所述更新数据进行动作。
进一步的,为了后台服务器与客户端侧的嵌入式系统之间实现一对多的形式,所述同步数据包携带有嵌入式系统的标识,如图6所示,所述步骤305之前,还包括:
步骤603,所述后台服务器根据所述嵌入式系统的标识以及所述嵌入式数据库的标识查找与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库。
所述步骤305,具体为:
所述后台服务器在所述与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库中,根据所述同步状态标识对所述更新数据进行相应的操作。
步骤306,在所述后台服务器完成数据库同步时,所述客户端将所述嵌入式数据库中的同步状态标识修改为完成状态。
具体的,如表8所示,在所述后台服务器完成数据库同步时,客户端将所述表7修改为表8所示的形式,使得完成同步后的数据为已同步状态,避免下一次数据库同步时进行不必要的动作。
表8:完成同步之后的更新数据
同步状态标识 | 学号 | 姓名 | 年龄 | 性别 | 系别 | 年级 |
DELETED | 981090 | 陈倩 | 22 | F | MA | 3 |
INSERTED | 981090 | 陈倩 | 23 | F | MA | 4 |
INSERTED | 991097 | 曾巩 | 19 | F | CS | 2 |
INSERTED | 991098 | 洪钧 | 20 | M | CS | 2 |
本发明实施例提供的数据库同步方法,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,节约了宝贵的卡上存储资源,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
如图8所示,本发明实施例提供的数据库同步装置,包括:
更新单元801,在进行嵌入式数据库更新时,用于在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成。其具体的实现方法可以参见如图1所示的步骤101所述,此处不再赘述。
在本实施例中,如图9所示,所述更新单元,包括:
第一接收子单元901,用于接收应用程序发送的更新请求,所述更新请求包括更新动作和所述更新数据;其具体的实现方法可以参见如图4所示的步骤401所述,此处不再赘述。
同步状态标识生成子单元902,用于根据所述第一接收子单元接收的更新动作生成同步状态标识;其具体的实现方法可以参见如图4所示的步骤402所述,此处不再赘述。
保存子单元903,用于将所述第一接收子单元接收的更新数据以及与所述更新数据对应的所述同步状态标识生成子单元生成的同步状态标识保存到嵌入式数据库中。其具体的实现方法可以参见如图4所示的步骤403所述,此处不再赘述。
同步单元802,在接收到后台服务器发送的同步请求时,用于将所述更新单元更新得到的嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器。其具体的实现方法可以参见如图1所示的步骤102所述,此处不再赘述。
在本实施例中,如图10所示,所述同步单元,包括:
第二接收子单元1001,用于接收后台服务器发送的同步请求;其具体的实现方法可以参见如图5所示的步骤501所述,此处不再赘述。
获取子单元1002,在所述第二接收子单元接收到所述同步请求时,用于获取在嵌入式数据库更新时保存的同步状态标识以及与所述同步状态标识相对应的更新数据;其具体的实现方法可以参见如图5所示的步骤502所述,此处不再赘述。
发送子单元1003,用于将所述获取单元获取的同步状态标识以及与所述同步状态标识相对应的更新数据发送给后台服务器。其具体的实现方法可以参见如图5所示的步骤503所述,此处不再赘述。
进一步的,所述同步单元,还用于在接收到后台服务器发送的同步请求时,将与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识发送给后台服务器。其具体的实现方法可以参见如图6所示的步骤601所述,此处不再赘述。
进一步的,如图11所示,所述数据库同步装置,还包括:
修改单元1101,在所述后台服务器完成数据库同步时,用于将所述嵌入式数据库中的同步状态标识修改为完成状态。其具体的实现方法可以参见如图3和图6所示的步骤306所述,此处不再赘述。
本发明实施例提供的智能卡,包括如图8-11所示的数据库同步装置,此处不再赘述。
本发明实施例提供的数据库同步装置,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,节约了宝贵的卡上存储资源,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
如图12所示,本发明实施例提供的后台服务器,包括:
发送单元1201,用于发送同步请求给客户端;其具体的实现方法可以参见如图2所示的步骤201所述,此处不再赘述。
接收单元1202,用于接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据;其具体的实现方法可以参见如图2所示的步骤202所述,此处不再赘述。
执行单元1203,用于根据所述接收单元接收的同步状态标识对所述接收单元接收的更新数据进行相应的操作。其具体的实现方法可以参见如图2所示的步骤203所述,此处不再赘述。
在本实施例中,如图13所示,所述执行单元,包括:
解析子单元1301,用于解析所述接收单元接收的同步状态标识,得到与所述同步状态标识对应的更新动作,所述更新动作包括删除和/或插入;其具体的实现方法可以参见如图7所示的步骤701所述,此处不再赘述。
执行子单元1302,根据所述解析子单元解析得到的更新动作对所述更新数据进行相应的操作。其具体的实现方法可以参见如图7所示的步骤702所述,此处不再赘述。
进一步的,如图14所示,所述接收单元1202,还用于接收所述客户端根据所述同步请求发送的与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识;其具体的实现方法可以参见如图6所示的步骤602所述,此处不再赘述。
所述后台服务器,还包括:
查找单元1401,用于根据所述接收单元接收的嵌入式系统的标识以及所述嵌入式数据库的标识查找与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库;其具体的实现方法可以参见如图6所示的步骤603所述,此处不再赘述。
所述执行单元1203,还用于在所述查找单元查找到的与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库中,根据所述同步状态标识对所述更新数据进行相应的操作。其具体的实现方法可以参见如图6所示的步骤305所述,此处不再赘述。
本发明实施例提供的后台服务器,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
如图15所示,本发明实施例提供的数据库同步系统,包括:
客户端1501,
在进行嵌入式数据库更新时,用于在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;
在接收到后台服务器发送的同步请求时,用于将嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器;
后台服务器1502,
用于发送同步请求给客户端;
用于接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据,根据所述同步状态标识对所述更新数据进行动作。
在本实施例中,所述客户端与图8-11所示的数据库同步装置结构基本相同,所述后台服务器与图12-14所示的后台服务器的结构基本相同,此处不再赘述。
值得说明的是,在本发明实施例中,所述客户端与后台服务器之间可以采用JMS(Java Message Service,Java消息服务)进行通信,JMS是J2EE标准的一部分,有利于同步软件和不同软件操作系统的兼容。
本发明实施例提供的数据库同步系统,在进行嵌入式数据库更新时,将更新的数据保存至嵌入式数据库中,并将根据所述更新数据的更新动作生成的同步状态标识对应所述更新数据保存至所述嵌入式数据库,使得后台服务器要进行后台服务器数据库与所述嵌入式数据库同步时,只需要在所述嵌入式数据库中查找同步状态标识,将所述同步状态标识以及与所述同步状态对应的更新数据发送给后台服务器即可实现,所述同步状态标识在所述嵌入式数据库中所占的空间较小,有效地减少了更新数据需要进行同步时所占的存储空间,节约了宝贵的卡上存储资源,从而降低了嵌入式系统的成本,解决了现有技术中嵌入式数据库同步需要消耗大量额外存储空间的问题。
本发明实施例提供的数据库同步方法、装置和系统,能够应用于嵌入式系统的数据库同步中,如智能卡中嵌入式数据库的同步。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分步骤是可以通过程序来指令相关的硬件完成,所述的程序可以存储于一计算机可读存储介质中,如ROM/RAM、磁碟或光盘等。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以所述权利要求的保护范围为准。
Claims (18)
1.一种数据库同步的方法,其特征在于,包括:
在进行嵌入式数据库更新时,在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;
在接收到后台服务器发送的同步请求时,将所述嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器。
2.根据权利要求1所述的方法,其特征在于,所述在进行嵌入式数据库更新时,在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,包括:
接收应用程序发送的更新请求,所述更新请求包括更新动作和所述更新数据;
根据所述更新动作生成同步状态标识;
将所述更新数据以及与所述更新数据对应的同步状态标识保存到所述嵌入式数据库中。
3.根据权利要求1所述的方法,其特征在于,所述在接收到后台服务器发送的同步请求时,将所述嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器,包括:
接收后台服务器发送的同步请求;
在接收到所述同步请求时,获取在所述嵌入式数据库更新时保存的同步状态标识以及与所述同步状态标识相对应的更新数据;
将所述同步状态标识以及与所述同步状态标识相对应的更新数据发送给后台服务器。
4.根据权利要求1-3任一项所述的方法,其特征在于,还包括:
在接收到后台服务器发送的同步请求时,将与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识发送给后台服务器。
5.根据权利要求4所述的方法,其特征在于,还包括:
在所述后台服务器完成数据库同步时,将所述嵌入式数据库中的同步状态标识修改为完成状态。
6.一种数据库同步的方法,其特征在于,包括:
发送同步请求给客户端;
接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据;
根据所述同步状态标识对所述更新数据进行相应的操作。
7.根据权利要求6所述的方法,其特征在于,所述根据所述同步状态标识对所述更新数据进行动作,包括:
解析所述同步状态标识,得到与所述同步状态标识对应的更新动作,所述更新动作包括删除和/或插入;
根据所述更新动作对所述更新数据进行相应的操作。
8.根据权利要求6或7所述的方法,其特征在于,所述方法还包括:
接收所述客户端根据所述同步请求发送的与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识;
根据所述嵌入式系统的标识以及所述嵌入式数据库的标识查找与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库;
所述根据所述同步状态标识对所述更新数据进行相应的操作,包括:
在与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库中,根据所述同步状态标识对所述更新数据进行相应的操作。
9.一种数据库同步装置,其特征在于,包括:
更新单元,在进行嵌入式数据库更新时,用于在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;
同步单元,在接收到后台服务器发送的同步请求时,用于将所述更新单元更新得到的嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器。
10.根据权利要求9所述的同步装置,其特征在于,所述更新单元,包括:
第一接收子单元,用于接收应用程序发送的更新请求,所述更新请求包括更新动作和所述更新数据;
同步状态标识生成子单元,用于根据所述第一接收子单元接收的更新动作生成同步状态标识;
保存子单元,用于将所述第一接收子单元接收的更新数据以及与所述更新数据对应的所述同步状态标识生成子单元生成的同步状态标识保存到嵌入式数据库中。
11.根据权利要求9所述的同步装置,其特征在于,所述同步单元,包括:
第二接收子单元,用于接收后台服务器发送的同步请求;
获取子单元,在所述第二接收子单元接收到所述同步请求时,用于获取在嵌入式数据库更新时保存的同步状态标识以及与所述同步状态标识相对应的更新数据;
发送子单元,用于将所述获取单元获取的同步状态标识以及与所述同步状态标识相对应的更新数据发送给后台服务器。
12.根据权利要求9-11任一项所述的同步装置,其特征在于,所述同步单元,还用于
在接收到后台服务器发送的同步请求时,将与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识发送给后台服务器。
13.根据权利要求12的同步装置,其特征在于,还包括:
修改单元,在所述后台服务器完成数据库同步时,用于将所述嵌入式数据库中的同步状态标识修改为完成状态。
14.一种智能卡,其特征在于,包括权利要求9-13任一项所述的数据库同步装置。
15.一种后台服务器,其特征在于,包括:
发送单元,用于发送同步请求给客户端;
接收单元,用于接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据;
执行单元,用于根据所述接收单元接收的同步状态标识对所述接收单元接收的更新数据进行相应的操作。
16.根据权利要求15所述的后台服务器,其特征在于,所述执行单元,包括:
解析子单元,用于解析所述接收单元接收的同步状态标识,得到与所述同步状态标识对应的更新动作,所述更新动作包括删除和/或插入;
执行子单元,根据所述解析子单元解析得到的更新动作对所述更新数据进行相应的操作。
17.根据权利要求15或16所述的后台服务器,其特征在于,
所述接收单元,还用于接收所述客户端根据所述同步请求发送的与所述同步状态标识对应的嵌入式数据库的标识以及与所述嵌入式数据库对应的嵌入式系统的标识;
所述后台服务器,还包括:
查找单元,用于根据所述接收单元接收的嵌入式系统的标识以及所述嵌入式数据库的标识查找与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库;
所述执行单元,还用于在所述查找单元查找到的与所述嵌入式系统的标识对应的嵌入式系统中的与所述嵌入式数据库的标识对应的嵌入式数据库中,根据所述同步状态标识对所述更新数据进行相应的操作。
18.一种数据库同步系统,其特征在于,包括:
客户端,
在进行嵌入式数据库更新时,用于在所述嵌入式数据库中保存更新数据以及与所述更新数据对应的同步状态标识,所述同步状态标识根据所述更新数据的更新动作生成;
在接收到后台服务器发送的同步请求时,用于将嵌入式数据库中的同步状态标识以及与所述同步状态标识对应的更新数据发送给所述后台服务器;
后台服务器,
用于发送同步请求给客户端;
用于接收所述客户端根据所述同步请求发送的同步状态标识以及与所述同步状态标识对应的更新数据,根据所述同步状态标识对所述更新数据进行相应的操作。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201010578325 CN102024040A (zh) | 2010-12-08 | 2010-12-08 | 数据库同步方法、装置和系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201010578325 CN102024040A (zh) | 2010-12-08 | 2010-12-08 | 数据库同步方法、装置和系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN102024040A true CN102024040A (zh) | 2011-04-20 |
Family
ID=43865337
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN 201010578325 Pending CN102024040A (zh) | 2010-12-08 | 2010-12-08 | 数据库同步方法、装置和系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN102024040A (zh) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102387213A (zh) * | 2011-10-25 | 2012-03-21 | 中兴通讯股份有限公司 | 数据同步方法及装置 |
CN102801782A (zh) * | 2012-06-28 | 2012-11-28 | 大唐移动通信设备有限公司 | 一种数据的同步更新方法和系统 |
CN103312728A (zh) * | 2012-03-06 | 2013-09-18 | 腾讯科技(深圳)有限公司 | 一种存储系统间的数据同步方法、系统和装置 |
CN103580891A (zh) * | 2012-07-27 | 2014-02-12 | 腾讯科技(深圳)有限公司 | 一种数据同步的方法、系统及服务器 |
WO2014079290A1 (zh) * | 2012-11-26 | 2014-05-30 | 腾讯科技(深圳)有限公司 | 对用户的长关系链数据的处理系统和方法 |
CN105791350A (zh) * | 2014-12-22 | 2016-07-20 | 博雅网络游戏开发(深圳)有限公司 | 项目数据处理方法和系统 |
CN109614222A (zh) * | 2018-10-30 | 2019-04-12 | 成都飞机工业(集团)有限责任公司 | 一种多线程资源分配方法 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1591350A (zh) * | 2003-08-26 | 2005-03-09 | 华为技术有限公司 | 一种使前后台数据库中数据相一致的方法 |
CN101075864A (zh) * | 2007-07-16 | 2007-11-21 | 腾讯科技(深圳)有限公司 | 数据同步方法及处理方法、客户端设备、服务器 |
CN101673295A (zh) * | 2009-08-28 | 2010-03-17 | 金蝶软件(中国)有限公司 | 一种数据同步控制方法、装置和单点登录系统 |
-
2010
- 2010-12-08 CN CN 201010578325 patent/CN102024040A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1591350A (zh) * | 2003-08-26 | 2005-03-09 | 华为技术有限公司 | 一种使前后台数据库中数据相一致的方法 |
CN101075864A (zh) * | 2007-07-16 | 2007-11-21 | 腾讯科技(深圳)有限公司 | 数据同步方法及处理方法、客户端设备、服务器 |
CN101673295A (zh) * | 2009-08-28 | 2010-03-17 | 金蝶软件(中国)有限公司 | 一种数据同步控制方法、装置和单点登录系统 |
Cited By (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102387213A (zh) * | 2011-10-25 | 2012-03-21 | 中兴通讯股份有限公司 | 数据同步方法及装置 |
CN103312728A (zh) * | 2012-03-06 | 2013-09-18 | 腾讯科技(深圳)有限公司 | 一种存储系统间的数据同步方法、系统和装置 |
CN103312728B (zh) * | 2012-03-06 | 2016-03-30 | 腾讯科技(深圳)有限公司 | 一种存储系统间的数据同步方法、系统和装置 |
CN102801782B (zh) * | 2012-06-28 | 2015-12-02 | 大唐移动通信设备有限公司 | 一种数据的同步更新方法和系统 |
CN102801782A (zh) * | 2012-06-28 | 2012-11-28 | 大唐移动通信设备有限公司 | 一种数据的同步更新方法和系统 |
CN103580891A (zh) * | 2012-07-27 | 2014-02-12 | 腾讯科技(深圳)有限公司 | 一种数据同步的方法、系统及服务器 |
CN103838757A (zh) * | 2012-11-26 | 2014-06-04 | 腾讯科技(深圳)有限公司 | 对用户的长关系链数据的处理系统和方法 |
WO2014079290A1 (zh) * | 2012-11-26 | 2014-05-30 | 腾讯科技(深圳)有限公司 | 对用户的长关系链数据的处理系统和方法 |
CN103838757B (zh) * | 2012-11-26 | 2017-06-09 | 腾讯科技(深圳)有限公司 | 对用户的长关系链数据的处理系统和方法 |
US9754006B2 (en) | 2012-11-26 | 2017-09-05 | Tencent Technology (Shenzhen) Company Limited | System and method for processing long relation chain data of user |
CN105791350A (zh) * | 2014-12-22 | 2016-07-20 | 博雅网络游戏开发(深圳)有限公司 | 项目数据处理方法和系统 |
CN105791350B (zh) * | 2014-12-22 | 2019-08-30 | 博雅网络游戏开发(深圳)有限公司 | 项目数据处理方法和系统 |
CN109614222A (zh) * | 2018-10-30 | 2019-04-12 | 成都飞机工业(集团)有限责任公司 | 一种多线程资源分配方法 |
CN109614222B (zh) * | 2018-10-30 | 2022-04-08 | 成都飞机工业(集团)有限责任公司 | 一种多线程资源分配方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102024040A (zh) | 数据库同步方法、装置和系统 | |
US20170161297A1 (en) | Data synchronization in a storage network | |
CN101064630B (zh) | 一种数据同步方法及系统 | |
CN1988535B (zh) | 文件存储同步方法、系统及客户端 | |
CN103051723A (zh) | 一种增量升级方法及服务器、终端 | |
CN109542865A (zh) | 分布式集群系统配置文件同步方法、装置、系统及介质 | |
CN104202440B (zh) | 一种标识终端的方法、服务器及系统 | |
CN111400407B (zh) | 数据的同步方法及装置、存储介质及电子装置 | |
CN101902473B (zh) | 基于网格gis的数据同步更新实现方法 | |
CN109376197B (zh) | 一种数据同步方法、服务器及计算机存储介质 | |
CN107181686B (zh) | 路由表的同步方法、装置及系统 | |
CN102202087B (zh) | 一种标识存储设备的方法及系统 | |
JP2007074724A (ja) | デジタル放送ネットワークでサーバとクライアントとの間のepg情報を同期化させるための方法及び装置 | |
CN105338078A (zh) | 用于存储系统的数据存储方法和装置 | |
CN101677325A (zh) | 发布媒体描述信息和获取媒体的方法、装置、系统 | |
CN102012899A (zh) | 一种数据更新的方法、系统及设备 | |
CN106709066B (zh) | 数据同步方法及装置 | |
CN102904977A (zh) | 网络地址分配方法、服务器和节点 | |
CN101741569B (zh) | 数据同步方法、系统及客户端、服务器 | |
CN103164525A (zh) | Web应用发布方法和装置 | |
CN102571923A (zh) | 数据同步系统及方法 | |
CN113633981A (zh) | 游戏应用中地图数据同步的方法、装置、设备及存储介质 | |
CN102289511B (zh) | 一种字库文件下载方法、用户端及服务器 | |
CN103905201B (zh) | 主应用与多个从属应用的交互方法及装置 | |
CN111367916B (zh) | 一种数据存储方法及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C12 | Rejection of a patent application after its publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20110420 |