[發明專利]數據處理方法、裝置、電子設備和存儲介質在審
| 申請號: | 202110605117.2 | 申請日: | 2021-05-31 |
| 公開(公告)號: | CN113342539A | 公開(公告)日: | 2021-09-03 |
| 發明(設計)人: | 王樹賀 | 申請(專利權)人: | 北京達佳互聯信息技術有限公司 |
| 主分類號: | G06F9/52 | 分類號: | G06F9/52;G06F16/21 |
| 代理公司: | 北京博思佳知識產權代理有限公司 11415 | 代理人: | 陳蕾 |
| 地址: | 100085 北京市海淀*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 數據處理 方法 裝置 電子設備 存儲 介質 | ||
本公開關于數據處理方法、裝置、電子設備和存儲介質。所述方法包括:接收針對第一數據的任一第一處理請求,所述第一數據的數據信息表明所述第一數據的邏輯層級低于第二數據的邏輯層級;在所述第二數據未被設置排它鎖的情況下,按照所述任一第一處理請求對所述第二數據的計數器的當前值增加預設數值;響應于所述任一第一處理請求處理所述第一數據,并在處理完成后,為所述計數器的當前值減少所述預設數值,其中,在所述計數器的當前值等于預設的計數初始值的情況下,所述第二數據能夠被處理。
技術領域
本公開涉及數據管理領域,尤其涉及一種數據處理方法、裝置、電子設備和存儲介質。
背景技術
對于數據庫中存儲的數據,通常可以進行增加、刪除、修改等操作。以多種業務層級對應的多層級數據為例,不同層級對應的線程對相應層級的數據進行上述操作可能會產生臟數據,從而影響業務系統穩定性。例如,數據庫可以按照項目-任務組-任務-子任務等從高到低的層級順序存儲業務數據,若高層級線程A(如項目線程)在刪除某任務組數據(該任務組的相關數據,下同)時,低層級線程B(如該任務組的內部線程)正在該任務組中創建任務,則線程B創建任務成功后,可能查詢不到新建任務所在的任務組,因為該任務組已被線程A刪除,導致該新建任務的任務數據成為臟數據。
針對這一問題,相關技術中采用分布式鎖加以解決,例如由低層級線程B對任務創建操作對應的項目數據添加排它鎖,從而在低線程B創建任務的時間段內排除其他線程針對該項目數據的操作,以避免產生臟數據。然而,若同一實現還存在低線程C、低線程D等請求操作同一項目組內的多個項目數據,則因為上述排它鎖的存在,其他低層級線程只能等待低線程B操作完成才能夠依次進行操作,從而導致數據庫的數據處理效率降低,極大影響了業務系統的吞吐量。
發明內容
本公開提供了數據處理方法、裝置、電子設備和存儲介質,以至少解決相關技術中的技術問題。本公開的技術方案如下:
根據本公開實施例的第一方面,提出一種數據處理方法,包括:
接收針對第一數據的任一第一處理請求,所述第一數據的數據信息表明所述第一數據的邏輯層級低于第二數據的邏輯層級;
在所述第二數據未被設置排它鎖的情況下,按照所述任一第一處理請求對所述第二數據的計數器的當前值增加預設數值;
響應于所述任一第一處理請求處理所述第一數據,并在處理完成后,為所述計數器的當前值減少所述預設數值,其中,在所述計數器的當前值等于預設的計數初始值的情況下,所述第二數據能夠被處理。
可選的,還包括:
在所述第二數據被設置有排它鎖的情況下,終止針對所述任一第一處理請求的響應過程;或者,
在所述第二數據被設置有排它鎖的情況下,等待第一時長后重新檢查所述第二數據是否被設置有排它鎖,若在針對所述排它鎖的檢查次數達到第一次數時,所述第二數據仍被設置有排它鎖,則終止針對所述任一第一處理請求的響應過程。
可選的,還包括:
在接收到針對所述第二數據的第二處理請求的情況下,為所述第一數據和第二數據設置排它鎖;
若所述計數器的當前值等于所述計數初始值,則響應于所述第二處理請求處理所述第二數據;
若所述計數器的當前值大于所述計數初始值,則終止響應所述第二處理請求,或者等待直至所述計數器的當前值等于所述計數初始值時,響應于所述第二處理請求處理所述第二數據;
在處理所述第二數據完成后釋放為所述第一數據和第二數據設置的排它鎖。
可選的,還包括:
在終止針對任一請求的響應過程后,向所述任一請求的發起方返回針對所述任一請求的響應失敗消息。
可選的,還包括:
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于北京達佳互聯信息技術有限公司,未經北京達佳互聯信息技術有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202110605117.2/2.html,轉載請聲明來源鉆瓜專利網。





