[發明專利]一種保持數據一致性的方法、裝置及系統在審
| 申請號: | 202011558725.4 | 申請日: | 2020-12-25 |
| 公開(公告)號: | CN112597246A | 公開(公告)日: | 2021-04-02 |
| 發明(設計)人: | 涂銳;王憲剛;邵碩 | 申請(專利權)人: | 中國農業銀行股份有限公司 |
| 主分類號: | G06F16/27 | 分類號: | G06F16/27 |
| 代理公司: | 北京集佳知識產權代理有限公司 11227 | 代理人: | 張柳 |
| 地址: | 100005 北*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 一種 保持 數據一致性 方法 裝置 系統 | ||
1.一種保持數據一致性的方法,其特征在于,應用于分布式系統中的第一服務設備,所述方法包括:
針對需要協同所述分布式系統中的第二服務設備操作的聯機交易,若所述第一服務設備操作成功,但所述第二服務設備操作失敗,則在流水表中記錄所述聯機交易的異常流水;
在預設的補償時段,從所述流水表中篩選待補償的異常流水,組成目標異常流水集合;
根據所述目標異常流水集合中的各異常流水和所述第一服務設備對應的第一數據庫中的當前交易操作數據,在補償文件中寫入補償數據,以使所述第二服務設備根據所述補償文件對其對應的第二數據庫進行數據補償。
2.根據權利要求1所述的保持數據一致性的方法,其特征在于,所述異常流水中記錄有交易時間戳;
所述從所述流水表中篩選待補償的異常流水,包括:
根據所述流水表中各異常流水中記錄的交易時間戳,順序從所述流水表中篩選待補償的異常流水。
3.根據權利要求1所述的保持數據一致性的方法,其特征在于,所述異常流水中記錄有交易流水號、數據庫操作類型和待補償數據的關鍵字段;
所述根據所述目標異常流水集合中的各異常流水和所述第一服務設備對應的第一數據庫中的當前交易操作數據,在補償文件中寫入補償數據,包括:
針對所述目標異常流水集合中每個待補償的目標異常流水:
根據所述目標異常流水中記錄的待補償數據和數據庫操作類型,以及所述第一數據庫中的當前交易操作數據,確定是否需要在所述第二數據庫中針對所述目標異常流水進行數據補償;
若是,則根據所述目標異常流水記錄的數據庫操作類型,以及所述第一數據庫中所述目標異常流水記錄的交易流水號對應的當前交易操作數據,生成操作語句,并將所述操作語句寫入補償文件。
4.根據權利要求3所述的保持數據一致性的方法,其特征在于,所述根據所述目標異常流水中記錄的待補償數據和數據庫操作類型,以及所述第一數據庫中的當前交易操作數據,確定是否需要在所述第二數據庫中針對所述目標異常流水進行數據補償,包括:
若所述目標異常流水中記錄的數據庫操作類型為新增,且在補償執行時刻所述第一數據庫中的當前交易操作數據中存在所述目標異常流水中記錄的待補償數據,則確定需要在所述第二數據庫中針對所述目標異常流水進行數據補償;
若所述目標異常流水中記錄的數據庫操作類型為刪除,且在補償執行時刻所述第一數據庫中的當前交易操作數據中不存在所述目標異常流水中記錄的待補償數據,則確定需要在所述第二數據庫中針對所述目標異常流水進行數據補償;
若所述目標異常流水中記錄的數據庫操作類型為修改,且在補償執行時段所述第一數據庫中的當前交易操作數據中存在所述目標異常流水中記錄的待補償數據,則確定需要在所述第二數據庫中針對所述目標異常流水進行數據補償。
5.根據權利要求3所述的保持數據一致性的方法,其特征在于,所述根據所述目標異常流水記錄的數據庫操作類型,以及所述第一數據庫中所述目標異常流水記錄的交易流水號對應的當前交易操作數據,生成操作語句,包括:
若所述目標異常流水中記錄的數據庫操作類型為新增,則根據補償時段所述第一數據庫中所述目標異常流水記錄的交易流水號對應的當前交易操作數據,生成插入語句;
若所述目標異常流水中記錄的數據庫操作類型為刪除,則根據補償時段所述第一數據庫中所述目標異常流水記錄的交易流水號對應的當前交易操作數據,生成刪除語句;
若所述目標異常流水中記錄的數據庫操作類型為修改,則根據所述第一數據庫中所述目標異常流水記錄的交易流水號對應的當前交易操作數據,生成修改語句。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于中國農業銀行股份有限公司,未經中國農業銀行股份有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202011558725.4/1.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:一種數據處理方法及裝置
- 下一篇:一種代餐食品及其制備方法





