[发明专利]事务批量处理方法及装置在审

专利信息
申请号: 202111424141.2 申请日: 2021-11-26
公开(公告)号: CN113986941A 公开(公告)日: 2022-01-28
发明(设计)人: 易金华;郭锦帅;林楷坤 申请(专利权)人: 中国银行股份有限公司
主分类号: G06F16/23 分类号: G06F16/23
代理公司: 北京集佳知识产权代理有限公司 11227 代理人: 李慧慧
地址: 100818 *** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 事务 批量 处理 方法 装置
【说明书】:

发明公开了事务批量处理方法及装置,可应用于金融领域或其他领域。通过获取批量数据;将批量数据进行划分,得到多个事务,每一事务处理一批数据,一批数据包含多条待处理记录;执行事务,利用SQL语句对一批数据进行相关业务逻辑处理,得到处理结果;设计通用机制,并根据处理结果,应用通用机制处理事务。在本方案中,通过将批量数据划分为多个事务,利用SQL语句对每个事务处理的一批数据进行处理,并根据得到的处理结果进行相应的事务控制操作,从而保证性能和数据一致性。

技术领域

本发明涉及数据库事务处理技术领域,尤其涉及一种事务批量处理方法及装置。

背景技术

批量处理是数据库常用的事务处理方式,在批量处理过程中,当个别记录格式错误或逻辑问题导致批量处理异常时,通常先回滚事务然后变成逐条记录处理,跳过这条引发错误的记录,并把跳过的记录到异常日志中,此时仅回滚这条跳过的记录引发的事务,不影响其它正常记录的事务成功。

由此可知,现有的批量处理方法没有引入剔除错误并递归调用的方式,在个别记录异常情况下不能最大化保证性能,且某些情况也没有考虑savepoint,以保证单条记录的事务一致性。

发明内容

有鉴于此,本发明实施例提供一种事务批量处理方法及装置,以实现保证性能和事务一致性的目的。

为实现上述目的,本发明实施例提供如下技术方案:

本发明实施例第一方面公开了一种事务批量处理方法,所述方法包括:

获取待处理的批量数据;

将所述批量数据进行划分,得到多个事务,每一所述事务处理一批数据,所述一批数据包含多条待处理记录;

执行所述事务,利用SQL语句对所述一批数据进行相关业务逻辑处理,得到处理结果;

设计通用机制,并根据所述处理结果,应用所述通用机制处理所述事务。

可选的,所述设计通用机制,并根据所述处理结果,应用所述通用机制处理所述事务,包括:

设计通用机制,若所述处理结果为处理成功结果,应用所述通用机制提交所述事务。

可选的,所述设计通用机制,并根据所述处理结果,应用所述通用机制处理所述事务,包括:

设计通用机制,若所述处理结果为处理失败结果,应用所述通用机制回滚所述事务;

逐条处理所述待处理记录,直至处理完所有待处理记录。

可选的,在所述逐条处理所述待处理记录之前,还包括:

设置回滚点。

可选的,所述逐条处理所述待处理记录,直至处理完所有待处理记录,包括:

重新逐条处理所述待处理记录;

当任意所述待处理记录发生错误时,跳过所述待处理记录,并将所述待处理记录产生的事务回滚至所述回滚点。

可选的,还包括:

获取剩余的待处理记录;

再次利用SQL语句对所述剩余的待处理记录进行递归调用处理,直至处理完所有剩余的待处理记录。

本发明实施例第二方面公开了一种事务批量处理装置,所述装置包括:

获取模块,用于获取待处理的批量数据;

划分模块,用于将所述批量数据进行划分,得到多个事务,每一所述事务处理一批数据,所述一批数据包含多条待处理记录;

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

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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