[发明专利]数据存储方法及系统、设备和存储介质有效

专利信息
申请号: 201810884035.4 申请日: 2018-08-06
公开(公告)号: CN109359222B 公开(公告)日: 2021-07-06
发明(设计)人: 王志文;吴思进 申请(专利权)人: 杭州复杂美科技有限公司
主分类号: G06F16/901 分类号: G06F16/901;G06F16/903;G06Q40/04
代理公司: 暂无信息 代理人: 暂无信息
地址: 310000 浙江省杭州市*** 国省代码: 浙江;33
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 数据 存储 方法 系统 设备 介质
【权利要求书】:

1.一种数据存储方法,其特征在于,包括:

通过全局索引表查询交易所需的业务数据;

根据所述业务数据和所述交易构建最新版本的默克尔树;

根据所述最新版本的默克尔树在节点本地的第一数据库中生成或更新全局索引表,并生成所述全局索引表的存储完成信息,以供所述节点中的共识单元将所述最新版本的默克尔树的根节点哈希打包至区块中进行共识;

根据所述最新版本的默克尔树在节点本地的第二数据库中生成或更新每个区块的默克尔树;

其中,所述全局索引表以区块高度为版本号,用于根据所述区块高度进行数据查询。

2.根据权利要求1所述的方法,其特征在于,所述根据所述最新版本的默克尔树在节点本地的第一数据库中生成或更新全局索引表,并生成所述全局索引表的存储完成信息,以供所述节点中的共识单元将所述最新版本的默克尔树的根节点哈希打包至区块中进行共识之后还包括:

在所述节点崩溃后,根据所述全局索引表在所述第二数据库中恢复所述每个区块的默克尔树。

3.根据权利要求1-2任一项所述的方法,其特征在于,所述全局索引表在每个版本中只记录当前版本的默克尔树中新增或修改的叶子节点。

4.根据权利要求1-2任一项所述的方法,其特征在于,所述默克尔树为默克尔状态树,存储在键值(key-value)数据库中。

5.一种数据存储系统,配置在区块链网络的节点中,其特征在于,包括:

构建单元,配置用于通过全局索引表查询交易所需的业务数据,以及,根据所述业务数据和所述交易构建最新版本的默克尔树;

第一存储单元,配置用于根据所述最新版本的默克尔树在节点本地的第一数据库中生成或更新全局索引表,并生成所述全局索引表的存储完成信息,以供所述节点中的共识单元将所述最新版本的默克尔树的根节点哈希打包至区块中进行共识;

第二存储单元,配置用于根据所述最新版本的默克尔树在节点本地的第二数据库中生成或更新每个区块的默克尔树;

其中,所述全局索引表以区块高度为版本号,用于根据所述区块高度进行数据查询。

6.根据权利要求5所述的系统,其特征在于,所述第二存储单元进一步配置用于在所述节点崩溃后,根据所述全局索引表在所述第二数据库中恢复所述每个区块的默克尔树。

7.根据权利要求5-6任一项所述的系统,其特征在于,所述第一存储单元进一步配置用于在所述全局索引表的每个版本中只记录当前版本的默克尔树中新增或修改的叶子节点。

8.根据权利要求5-6任一项所述的系统,其特征在于,所述默克尔树为默克尔状态树,存储在键值(key-value)数据库中。

9.一种电子设备,其特征在于,所述电子设备包括:

一个或多个处理器;

存储器,用于存储一个或多个程序,

当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器执行如权利要求1-4中任一项所述的方法。

10.一种存储有计算机程序的存储介质,其特征在于,该程序被处理器执行时实现如权利要求1-4中任一项所述的方法。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州复杂美科技有限公司,未经杭州复杂美科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201810884035.4/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top