[發明專利]數據存儲、讀取方法及裝置在審
| 申請號: | 201810281901.0 | 申請日: | 2018-04-02 |
| 公開(公告)號: | CN108733744A | 公開(公告)日: | 2018-11-02 |
| 發明(設計)人: | 李榮峰;李長英 | 申請(專利權)人: | 東方視界科技(北京)有限公司 |
| 主分類號: | G06F17/30 | 分類號: | G06F17/30 |
| 代理公司: | 北京康信知識產權代理有限責任公司 11240 | 代理人: | 趙囡囡;張文華 |
| 地址: | 100012 北京市朝陽區*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 讀取 數據存儲 目標數據存儲 序列化處理 存儲數據 目標數據 申請 維護 | ||
本申請公開了一種數據存儲、讀取方法及裝置。其中,該方法包括:獲取數據表中所存儲數據的版本號建立數據表;將數據表中的數據和版本號進行序列化處理,得到目標數據;以及將目標數據存儲至數據表中。本申請解決了相關技術中數據表的維護成本較高的技術問題。
技術領域
本申請涉及數據存儲領域,具體而言,涉及一種數據存儲、讀取方法及裝置。
背景技術
隨著互聯網技術的發展、硬件的不斷更新、社會信息化的不斷深入,數據迎來了爆發式的增長,應用的復雜性要求越來越高,推動著數據存儲技術向著海量數據、分析數據、智能數據的方向發展,以便為數據倉庫、在線分析提供高效實時的技術支持。目前較流行的大數據存儲數據庫有:行存儲和列存儲。
基于行存儲技術和列存儲技術,存儲數據庫數據時,需要根據業務邏輯設置不同的字段(行存儲方式:行,列存儲方式:列)。當業務邏輯發生變化時,需要變化數據庫中數據表的結構,比如進行增加、刪除操作,修改數據庫的數據格式、更新數據內容等。偶爾變化則忽略其代價,經常變化業務邏輯,則數據庫維護代價高。
針對上述的問題,目前尚未提出有效的解決方案。
發明內容
本申請實施例提供了一種數據存儲、讀取方法及裝置,以至少解決相關技術中數據表的維護成本較高的技術問題。
根據本申請實施例的一個方面,提供了一種數據存儲方法,包括:獲取數據表中所存儲數據的版本號建立數據表;;將數據表中的數據和版本號進行序列化處理,得到目標數據;以及將目標數據存儲至數據表中存儲目標數據。
可選地,獲取數據表中所存儲數據的版本號之前,方法還包括:檢測數據表中的數據邏輯關系是否發生變化;在發生變化時,觸發生成與變化后的數據表對應的版本號。
可選地,數據邏輯關系包括:數據表中數據之間的關聯關系。
可選地,目標數據至少包括以下字段:版本號、數據表中的有效數據。
可選地,存儲目標數據,包括:獲取目標數據中所存儲數據的數據類型;確定與數據類型對應的表項,該表項為數據表中的表項;按照為表項分配的內存為各個數據類型的數據分配存儲資源;使用分配的存儲資源存儲目標數據。
可選地,存儲目標數據,包括:獲取目標數據中所存儲數據的數據類型;按照預設排列順序存儲數據類型所指示的數據。
根據本申請實施例的另一方面,提供了一種數據存儲方法,包括:獲取待存儲數據的版本號;將待存儲數據和版本號進行序列化處理,得到目標數據;以及將目標數據存儲至數據表中。
根據本申請實施例的另一方面,提供了一種數據讀取方法,包括:讀取數據表中的部分數據,其中,數據表用于存儲對待存儲數據進行序列化處理后得到的序列化數據;從部分數據中提取數據表的版本號;按照版本號確定與版本號對應的讀取規則;按照讀取規則讀取數據表中的剩余數據,其中,該剩余數據為數據表中除部分數據之外的數據。
可選地,讀取數據表中的部分數據,包括:讀取序列化數據中的指定數據,其中,該指定數據為序列化數據中前n個字節的數據,n為不小于1的整數。
根據本申請實施例的又一個方面,提供了一種存儲介質,存儲介質包括存儲的程序,其中,在程序運行時控制存儲介質所在設備執行以上所述的數據讀取方法或數據存儲方法。
根據本申請實施例的又一個方面,提供了一種處理器,處理器用于運行程序,其中,程序運行時執行以上所述的數據讀取方法或數據存儲方法。
根據本申請實施例的又一個方面,提供了一種數據存儲裝置,包括:獲取模塊,用于獲取數據表中所存儲數據的版本號;處理模塊,用于將數據和版本號進行序列化處理,得到目標數據;以及存儲目標數據。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于東方視界科技(北京)有限公司,未經東方視界科技(北京)有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201810281901.0/2.html,轉載請聲明來源鉆瓜專利網。





