一种数据存储方法、装置、设备及存储介质制造方法及图纸

技术编号:19857790 阅读:24 留言:0更新日期:2018-12-22 11:45
本发明专利技术实施例公开了一种数据存储方法、装置、设备及存储介质。该方法包括:依据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数;依据定义的有效位数确认目标存储方式和存储数据类型;依据定义数据类型转换待存储数据;依据目标存储方式和存储数据类型存储转换后的数据。通过本发明专利技术的技术方案,以实现提高数据的访问和更新速度。

【技术实现步骤摘要】
一种数据存储方法、装置、设备及存储介质
本专利技术实施例涉及数据库技术,尤其涉及一种数据存储方法、装置、设备及存储介质。
技术介绍
目前主流数据库都支持DEC数据类型,也称为DECIMAL、NUMBER或NUMERIC。DEC能够表示高达38位有效数字,可以在定义时指定有效数字的位数以及小数部分的位数。语法格式为:DEC[(P[,S])],其中“[]”表示可以缺省。P表示有效数字位数,取值范围[1,38];S表示小数位数,取值范围[0,P];整数位数为P-S。例如,123.45就是一个DEC(5,2)类型,有效位5,小数位2,整数位3。DEC数据类型区别于其它浮点数据类型。浮点数据类型是按照指数形式存储的,如float只能保证的有效数字是7位,后面的数字是无意义的,因此不能准确的表示该数,一般在内存中占4字节,分成小数部分和指数部分分别存放。而DEC是一种精确的数值数据类型,为了能够准确保留所有有效位,DEC一般是基于字节存储的。DEC存储字节数由实际数据的有效位数决定,一般采用变长方式存储。读取或更新DEC数据时,DEC变长存储严重影响了记录中数据整体的访问速度。
技术实现思路
本专利技术实施例提供一种数据存储方法、装置、设备及存储介质,以实现提高数据的访问速度和更新速度。第一方面,本专利技术实施例提供了一种数据存储方法,包括:根据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数;依据定义的有效位数确认目标存储方式和存储数据类型;依据定义数据类型转换待存储数据;依据目标存储方式和存储数据类型存储转换后的数据。进一步的,依据定义的有效位数确认目标存储方式包括:若所述定义的有效位数小于或者等于预设阈值,则确认目标存储方式为定长存储;若所述定义的有效位数大于预设阈值,则确认目标存储方式为变长存储。进一步的,定义数据类型包括定义小数位数;相应的,依据定义数据类型转换待存储数据包括:将所述待存储数据根据定义的小数位数放大预设倍数。进一步的,还包括:若所述待存储数据根据定义的小数位数进行转换后,所述转换后的待存储数据的有效位数与小数位数之差小于或者等于定义的有效位数与小数位数之差,则确定所述待存储数据有效。第二方面,本专利技术实施例还提供了一种数据读取方法,包括:根据定义的有效位数确认目标存储方式和存储数据类型;根据所述目标存储方式和存储数据类型获取数据的存储偏移;根据所述偏移和存储数据类型读取所述数据。进一步的,根据所述偏移和目标存储数据类型读取所述数据之后,还包括:获取定义的小数位数;根据所述小数位数将所述读取的数据缩小预设倍数。第三方面,本专利技术实施例还提供了一种数据存储装置,该装置包括:定义数据类型确认模块,用于根据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数;存储数据类型确认模块,用于依据定义的有效位数确认目标存储方式和存储数据类型;转换模块,用于依据定义数据类型转换待存储数据;存储模块,用于依据目标存储方式和存储数据类型存储转换后的数据。第四方面,本专利技术实施例还提供了一种数据读取装置,该装置包括:类型确认模块,用于根据定义的有效位数确认目标存储方式和存储数据类型;获取模块,用于根据所述目标存储方式和存储数据类型获取数据的存储偏移;读取模块,用于根据所述偏移和存储数据类型读取所述数据。第五方面,本专利技术实施例还提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如本专利技术实施例中任一所述的数据存储方法。第六方面,本专利技术实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本专利技术实施例中任一所述的数据存储方法。第七方面,本专利技术实施例还提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如本专利技术实施例中任一所述的数据读取方法。第八方面,本专利技术实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本专利技术实施例中任一所述的数据读取方法。本专利技术实施例通过依据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数;依据定义的有效位数确认目标存储方式和存储数据类型;依据定义数据类型转换待存储数据;依据目标存储方式和存储数据类型存储转换后的数据,以实现提高数据的访问和更新速度。附图说明为了更清楚地说明本专利技术实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本专利技术的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。图1A是本专利技术实施例一中的一种数据存储方法的流程图;图1B是本专利技术实施例一中的一种数据存储方法的图示;图2A是本专利技术实施例二中的一种数据读取方法的流程图;图2B是本专利技术实施例二中的一种数据读取方法的图示;图3是本专利技术实施例三中的一种数据存储装置的结构示意图;图4是本专利技术实施例四中的一种数据读取装置的结构示意图;图5是本专利技术实施例五中的一种计算机设备的结构示意图。具体实施方式下面结合附图和实施例对本专利技术作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅用于解释本专利技术,而非对本专利技术的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本专利技术相关的部分而非全部结构。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本专利技术的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。实施例一图1A为本专利技术实施例一提供的一种数据存储方法的流程图,本实施例可适用于数据存储的情况,该方法可以由本专利技术实施例中的数据存储装置来执行,该装置可采用软件和/或硬件的方式实现,如图1A所示,该方法具体包括如下步骤:S110,根据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数。其中,所述定义数据类型为DEC(P,S),其中,DEC为数据类型,P为定义的有效位数,S为定义的小数位数。其中,所述待存储数据为用户输入的需要存储的数据。具体的,根据用户输入的待存储数据确认定义数据类型。。其中,所述有效位数指的是待存储数据总共的位数,也就是小数位数和整数位数之和,例如,数据124.5,有效位数为4,小数位数为1,整数位数为3。例如可以是,若用户需要存储数据123.4、124.5、126,存储上述数据需要的数据类型为DEC数据类型,则用户根据需要存储的数据的最大有效位数为4位,最大小数位数为1,则确定定义数据类型为DEC(4,1)。S120,依据定义的有效位数确认目标存储方式和存储数据类型其中,所述存储数据类型包括:整型INT存储和整型INT64存储。其中,定义的有效位数在[1,9]为整型INT存储,定义的有效位数在[10,18]为整型INT64存储。其中,所述目标存储方式包括:定长存储和变长存储。具体的,根据定义的有效位数确定目标存储方式为定长存储还是变长存储,根据定义的有效位数确定存储数据类型,是整型INT存储还是整型INT64存储。可选的,依据定义的有效位数确认本文档来自技高网...

【技术保护点】
1.一种数据存储方法,其特征在于,包括:根据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数;依据定义的有效位数确认目标存储方式和存储数据类型;依据定义数据类型转换待存储数据;依据目标存储方式和存储数据类型存储转换后的数据。

【技术特征摘要】
1.一种数据存储方法,其特征在于,包括:根据待存储数据确认定义数据类型,其中,定义数据类型包括定义有效位数;依据定义的有效位数确认目标存储方式和存储数据类型;依据定义数据类型转换待存储数据;依据目标存储方式和存储数据类型存储转换后的数据。2.根据权利要求1所述的方法,其特征在于,依据定义的有效位数确认目标存储方式包括:若所述定义的有效位数小于或者等于预设阈值,则确认目标存储方式为定长存储;若所述定义的有效位数大于预设阈值,则确认目标存储方式为变长存储。3.根据权利要求1所述的方法,其特征在于,定义数据类型包括定义小数位数;相应的,依据定义数据类型转换待存储数据包括:将所述待存储数据根据定义的小数位数放大预设倍数。4.根据权利要求3所述的方法,其特征在于,还包括:若所述待存储数据根据定义的小数位数进行转换后,所述转换后的待存储数据的有效位数与小数位数之差小于或者等于定义的有效位数与小数位数之差,则确定所述待存储数据有效。5.一种数据读取方法,其特征在于,包括:根据定义的有效位数确认目标存储方式和存储数据类型;根据所述目标存储方式和存储数据类型获取数据的存储偏移;根据所述偏移和存储数据类型读取...

【专利技术属性】
技术研发人员:望声宜王家贤
申请(专利权)人:上海达梦数据库有限公司
类型:发明
国别省市:上海,31

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1