CN112632071A - 数据库主键id生成方法、装置、设备及存储介质 - Google Patents
数据库主键id生成方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN112632071A CN112632071A CN202011540536.4A CN202011540536A CN112632071A CN 112632071 A CN112632071 A CN 112632071A CN 202011540536 A CN202011540536 A CN 202011540536A CN 112632071 A CN112632071 A CN 112632071A
- Authority
- CN
- China
- Prior art keywords
- sequence
- increment
- self
- container
- target
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2228—Indexing structures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请实施例公开了一种数据库主键id生成方法、装置、设备及存储介质,涉及数据库信息处理技术领域。该方法包括:获取当前的时间戳;获取容器初始标识符,并将容器初始标识符转换为目标容器标识符;根据掩码长度定义一个以整数表示的运算掩码;获取自增序列,调用自增序列以获取自增序列号,并对自增序列号与运算掩码执行位运算获取目标序列号;对时间戳、目标容器标识符和目标序列号执行位运算,生成目标主键id。所述方法通过对包含多种数值独特性的多个参数值进行位运算,使生成的主键id在单机容器或多容器情况下都是不重复的,在提升主键id生产效率的同时,减小了自增主键时的数据库资源竞争,并避免了容易暴露业务量的问题。
Description
技术领域
本申请涉及数据库信息处理技术领域,特别是一种数据库主键id生成方法、装置、设备及存储介质。
背景技术
现有数据库的主键id(Identification,身份证明)生产方案一般有使用uuid(Universally Unique Identifier,通用唯一标识码)、主键自增或者开源的雪花算法等。
但以上主键id生成方式都有各自的缺陷:uuid会导致数据库分裂页,产生大量碎片以及插入数据慢等缺点;自增主键在分布式环境下最大值锁竞争激烈,也消耗性能,且最大的主键值即为业务量,容易暴露业务量;雪花算法为随机整数,也会导致数据库分页等缺陷。
发明内容
本申请实施例所要解决的技术问题是,提供一种数据库主键id生成方法、装置、设备及存储介质,提升主键id的生产效率,并减小数据库资源竞争和避免暴露业务量。
为了解决上述技术问题,本申请实施例提供一种数据库主键id生成方法,采用了如下所述的技术方案:
一种数据库主键id生成方法,包括:
基于预设的时间维度获取当前的时间戳;
获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符;
读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码;
获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号;
对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。
为了解决上述技术问题,本申请实施例还提供一种数据库主键id生成装置,采用了如下所述的技术方案:
一种数据库主键id生成装置,包括:
时间戳获取模块,用于基于预设的时间维度获取当前的时间戳;
容器标识获取模块,用于获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符;
掩码设置模块,用于读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码;
序列号计算模块,用于获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号;
主键id计算模块,用于对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,采用了如下所述的技术方案:
一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如上述任意一项技术方案所述的数据库主键id生成方法的步骤。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,采用了如下所述的技术方案:
一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如上述任意一项技术方案所述的数据库主键id生成方法的步骤。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例公开了一种数据库主键id生成方法、装置、设备及存储介质,本申请实施例所述的数据库主键id生成方法,首先基于预设的时间维度获取当前的时间戳;以及获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符;读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码;再获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号;最终通过对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。所述方法通过对包含多种数值独特性的多个参数值进行位运算,使生成的主键id在单机容器或多容器情况下都是不重复的,在提升主键id生产效率的同时,减小了自增主键时的数据库资源竞争,并避免了容易暴露业务量的问题。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例可以应用于其中的示例性系统架构图;
图2为本申请实施例中所述数据库主键id生成方法的一个实施例的流程图;
图3为本申请实施例中所述数据库主键id生成装置的一个实施例的结构示意图;
图4为本申请实施例中计算机设备的一个实施例的结构示意图。
具体实施方式
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同。本文中在本申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请。
需要说明的是,本申请的说明书和权利要求书及上述附图中的术语“包括”、“包含”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其他步骤或单元。在本申请的权利要求书、说明书以及说明书附图中的术语,诸如“第一”和“第二”等之类的关系术语仅仅用来将一个实体/操作/对象与另一个实体/操作/对象区分开来,而不一定要求或者暗示这些实体/操作/对象之间存在任何这种实际的关系或者顺序。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其他实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其他实施例相结合。
为了使本技术领域的人员更好地理解本申请的方案,下面将结合本申请实施例中的相关附图,对本申请实施例中的技术方案进行清楚、完整地描述。
如图1所示,系统架构100可以包括第一终端设备101、第二终端设备102、第三终端设备103、网络104和服务器105。网络104用以在第一终端设备101、第二终端设备102、第三终端设备103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用第一终端设备101、第二终端设备102和第三终端设备103通过网络104与服务器105交互,以接收或发送消息等。第一终端设备101、第二终端设备102和第三终端设备103上可以安装有各种通讯客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
第一终端设备101、第二终端设备102和第三终端设备103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture Experts Group Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving Picture Experts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对第一终端设备101、第一终端设备102和第三终端设备103上显示的页面提供支持的后台服务器。
需要说明的是,本申请实施例所提供的数据库主键id生成方法一般由服务器/终端设备执行,相应地,数据库主键id生成装置一般设置于服务器/终端设备中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了本申请实施例中所述数据库主键id生成方法的一个实施例的流程图。所述数据库主键id生成方法,包括以下步骤:
步骤201:基于预设的时间维度获取当前的时间戳。
本申请中,以时间维度表示时间戳描述时间的程度,如时间戳对应的“年月日时分秒”中的跨度。预设时间戳的时间维度后,便基于预设的时间维度截取出当前的时间戳,用于主键id的生成。
而时间戳在所述时间维度下的时间精度也需要预先设定,其中,时间精度按量级可分为:纳秒(ns)、皮秒(ps)、微秒(us)、毫秒(ms)、秒(s)、分(min)、小时(h)。在一种优选实施方式中,所述时间戳的时间精度设置为毫秒级。
步骤202:获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符。
本申请中主键id的生成过程可以由不同的容器并发执行,不同的容器对应不同的服务器,因此需要通过不同的标识符区分不同的容器,而不同的容器具有不同的服务器ip地址。在一种具体实施方式中,为了区分不同的容器,便可以通过获取当前数据库所在容器对应的ip地址后,将其转化为相应的整数进行标记。
在本申请的一些实施例中,所述步骤202包括:
获取容器对应的容器名称、服务器ip地址和机器码;
将所述容器名称、所述服务器ip地址和所述机器码进行组合后,通过哈希处理生成目标哈希值;
将所述目标哈希值转换为以无符号长整型表示的所述目标容器标识符。
该步骤中所生成的目标容器标识符针对每个服务器应是具有独特性的,但某些服务器机器码是相同的,甚至无法获取到机器码,比如阿里云服务器,虚拟主机等,即不同的主机机器码可能是相同的或者是空的。因此这里边需要使用到其他的机器信息,比如操作系统计算机名称,而且每台虚拟主机也同样具有不同的计算机名称,同时,每台虚拟主机也有不同的服务器ip地址。
将容器名称、服务器ip地址和机器码组合后进行哈希处理,得到对应的长整型数值后,便以该数值表示所述目标容器标识符。
步骤203:读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码。
掩码是一串二进制代码,用于对目标字段进行位与运算,以屏蔽当前的输入位。
本申请中,通过根据掩码长度定义一个以整数表示的运算掩码加入计算,其中,掩码长度指二进制下的位长度。一般地,所述运算掩码取在所述掩码长度下的整数最大值,如假设所述预设的掩码长度为64字节,即64x28bit,则所述运算掩码在该掩码长度下整数的最大取值为64x28-1=16383。
步骤204:获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号。
序列是一数据库对象,利用它可生成唯一的整数。自增序列在每次被调用时其中的值都会自动实现一次自增。
计算机程序中的所有数在计算机内存中都是以二进制的形式储存的,位运算就是直接对整数在内存中的二进制位进行操作。位运算包括:位与运算、位或运算、以及异或运算。本申请实施例中的位运算一般均采用位或运算。
位的与运算指,参加运算的两个数,按二进制位进行“与”运算。运算规则为:只有两个数的二进制同时为1,结果才为1,否则为0。
位的或运算则指,参加运算的两个数,按二进制位进行“或”运算。运算规则为:参加运算的两个数只要两个数中的一个为1,结果就为1。
位的异或运算指,参加运算的两个数,按二进制位进行“异或”运算。运算规则为:参加运算的两个数,如果两个相应位为“异”(值不同),则该位结果为1,否则为0。
在本申请实施例的一些实施方式中,步骤204中所述获取自增序列的步骤包括:
调用jdk中的AtomicInteger原子类;
访问所述AtomicInteger原子类对应的应用程序接口,通过getAndIncrement或incrementAndGet方法获取所述自增序列。
在JDK(Java Development Kit,Java语言的软件开发工具包)的java.util.concurrent.atomic包中提供有许多原子操作类,它们可以简单、高效、安全地更新一个变量。
AtomicInteger原子类指jdk中Atomic包中原子更新整形的原子操作类。通过AtomicInteger原子类的getAndIncrement方法和incrementAndGet方法可以以原子方式将当前值加1。其中,getAndIncrement方法是返回旧值(即加1前的原始值),incrementAndGet方法是返回新值(即加1后的值)。
在本申请的一些其他实施例中,步骤204中所述获取自增序列的步骤还包括:
调用预设的序列自增语句;
获取序列自增需求,所述自增需求中指定有序列自增时的初始序列号、序列间隔和序列最大值;
基于所述序列自增需求配置所述序列自增语句生成自增序列。
在本申请的该部分实施例中,服务器中预先配置有关于序列自增的标准语句,获取符合当前需求的自增序列时,便需要根据序列自增需求中指定的初始序列号、序列间隔和序列最大值等内容对该标准语句进行修改。一般地,初始序列号设为0或1,序列间隔(或指步长)的缺省值为1。
进一步的,所述基于所述序列自增需求配置所述序列自增语句生成自增序列的步骤还包括:
读取预设的回滚阈值;
比较所述序列最大值和所述回滚阈值的大小;
若所述序列最大值小于所述回滚阈值,则在所述序列自增语句中配置回滚操作,使序列号达到所述序列最大值后回退至所述初始序列号重新计数。
若基于系统限制或当前需求,序列最大值的设置难以满足主键id的生产需求,如可理解为自增序列号达到序列最大值后,主键id仍有产出需求。则可以根据当前的主键id生成数量的需求预先配置一个回滚阈值,若序列最大值小于该回滚阈值,则表示序列最大值不能最大地满足当前主键id的生产需求,便在修改所述序列自增语句时增加序列号的回滚操作,使序列号达到序列最大值后自动回退至所述初始序列号对应的数值重新计数自增。
在本申请实施例中,所述数据库主键id生成方法运行于其上的电子设备(例如图1所示的服务器/终端设备)可以通过有线连接方式或者无线连接方式接收发送至服务器的自增序列号。需要指出的是,上述无线连接方式可以包括但不限于3G/4G连接、WiFi连接、蓝牙连接、WiMAX连接、Zigbee连接、UWB(ultra wideband)连接、以及其他现在已知或将来开发的无线连接方式。
步骤205:对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。
最终通过对以整数表示的时间戳、目标容器地址和目标序列号执行位运算,便能生成对应以整数表示的主键id值,通过上述数值进行位运算,本申请实施例中生成的主键id值一般是对应19bit的整数值。该整数表示的主键id值在单容器内是独特的,不会产生重复的值,即使在高并发的情况下也只有整数的后几位可能会重复,其相较于uuid、主键自增和雪花算法插入数据的效率更高,且避免了自增主键时数据库资源竞争以及容易暴露业务量的问题。
本申请实施例所述的数据库主键id生成方法,通过对包含多种数值独特性的多个参数值进行位运算,使生成的主键id在单机容器或多容器情况下都是不重复的,在提升主键id生产效率的同时,减小了自增主键时的数据库资源竞争,并避免了容易暴露业务量的问题。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,该计算机程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
进一步参考图3,图3示出了为本申请实施例中所述数据库主键id生成装置的一个实施例的结构示意图。作为对上述图2所示方法的实现,本申请提供了一种数据库主键id生成装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图3所示,本实施例所述的数据库主键id生成装置包括:
时间戳获取模块301;用于基于预设的时间维度获取当前的时间戳。
容器标识获取模块302;用于获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符。
掩码设置模块303;用于读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码。
序列号计算模块304;用于获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号。
主键id计算模块305;用于对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。
在本申请的一些实施例中,所述容器标识获取模块302用于获取容器对应的容器名称、服务器ip地址和机器码;将所述容器名称、所述服务器ip地址和所述机器码进行组合后,通过哈希处理生成目标哈希值;将所述目标哈希值转换为以无符号长整型表示的所述目标容器标识符。
在本申请实施例的一些实施方式中,所述序列号计算模块304包括:自增序列获取子模块。所述自增序列获取子模块用于调用jdk中的AtomicInteger原子类;访问所述AtomicInteger原子类对应的应用程序接口,通过getAndIncrement或incrementAndGet方法获取所述自增序列。
在本申请的一些其他实施例中,所述容器标识获取模块302还包括:序列配置子模块。所述序列配置子模块用于调用预设的序列自增语句;获取序列自增需求,所述自增需求中指定有序列自增时的初始序列号、序列间隔和序列最大值;基于所述序列自增需求配置所述序列自增语句生成自增序列。
进一步的,所述序列配置子模块还用于读取预设的回滚阈值;比较所述序列最大值和所述回滚阈值的大小;若所述序列最大值小于所述回滚阈值,则在所述序列自增语句中配置回滚操作,使序列号达到所述序列最大值后回退至所述初始序列号重新计数。
本申请实施例所述的数据库主键id生成装置,通过对包含多种数值独特性的多个参数值进行位运算,使生成的主键id在单机容器或多容器情况下都是不重复的,在提升主键id生产效率的同时,减小了自增主键时的数据库资源竞争,并避免了容易暴露业务量的问题。
为解决上述技术问题,本申请实施例还提供计算机设备。具体请参阅图4,图4为本实施例计算机设备基本结构框图。
所述计算机设备6包括通过系统总线相互通信连接存储器61、处理器62、网络接口63。需要指出的是,图中仅示出了具有组件61-63的计算机设备6,但是应理解的是,并不要求实施所有示出的组件,可以替代的实施更多或者更少的组件。其中,本技术领域技术人员可以理解,这里的计算机设备是一种能够按照事先设定或存储的指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(ApplicationSpecific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable GateArray,FPGA)、数字处理器(Digital Signal Processor,DSP)、嵌入式设备等。
所述计算机设备可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机设备可以与用户通过键盘、鼠标、遥控器、触摸板或声控设备等方式进行人机交互。
所述存储器61至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等。在一些实施例中,所述存储器61可以是所述计算机设备6的内部存储单元,例如该计算机设备6的硬盘或内存。在另一些实施例中,所述存储器61也可以是所述计算机设备6的外部存储设备,例如该计算机设备6上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(FlashCard)等。当然,所述存储器61还可以既包括所述计算机设备6的内部存储单元也包括其外部存储设备。本实施例中,所述存储器61通常用于存储安装于所述计算机设备6的操作系统和各类应用软件,例如数据库主键id生成方法的程序代码等。此外,所述存储器61还可以用于暂时地存储已经输出或者将要输出的各类数据。
所述处理器62在一些实施例中可以是中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器、或其他数据处理芯片。该处理器62通常用于控制所述计算机设备6的总体操作。本实施例中,所述处理器62用于运行所述存储器61中存储的程序代码或者处理数据,例如运行所述数据库主键id生成方法的程序代码。
所述网络接口63可包括无线网络接口或有线网络接口,该网络接口63通常用于在所述计算机设备6与其他电子设备之间建立通信连接。
本申请实施例所述的计算机设备,通过处理器执行存储器中存储的计算机程序进行数据推送的功能测试时,无需通过前端操作创建任务,能够实现对大批量数据库主键id生成要求,并减少测试时间的消耗,提升功能测试的效率,在进行数据推送测试的过程中还能方便地进行压力测试,在通过日志判断数据的推送结果时还能方便分析测试时出现的问题,以及对测试过程中出现的问题进行定位。
本申请还提供了另一种实施方式,即提供一种计算机可读存储介质,所述计算机可读存储介质存储有数据库主键id生成程序,所述数据库主键id生成程序可被至少一个处理器执行,以使所述至少一个处理器执行如上述的数据库主键id生成方法的步骤。
需要强调的是,为进一步保证上述图片数据的私密和安全性,上述图片数据还可以存储于一区块链的节点中。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
在本申请所提供的上述实施例中,应该理解到,所揭露的装置和方法,可以通过其他的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如,多个模块或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。
所述模块或组件可以是或者也可以不是物理上分开的,作为模块或组件显示的部件可以是或者也可以不是物理模块,既可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块或组件来实现本实施例方案的目的。
本申请不限于上述实施方式,以上所述是本申请的优选实施方式,该实施例仅用于说明本申请而不用于限制本申请的范围,应当指出,对于本技术领域的普通技术人员来说,在不脱离本申请原理的前提下,其依然可以对前述各具体实施方式所记载的技术方案进行若干改进和修饰,或者对其中部分技术特征进行等效替换。凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理应视为包括在本申请的保护范围之内。
显然,以上所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例,附图中给出了本申请的较佳实施例,但并不限制本申请的专利范围。本申请可以以许多不同的形式来实现,相反地,提供这些实施例的目的是使对本申请的公开内容的理解更加透彻全面。尽管参照前述实施例对本申请进行了详细的说明,对于本领域的技术人员来而言,其依然可以对前述各具体实施方式所记载的技术方案进行修改,或者对其中部分技术特征进行等效替换。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,以及凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理在本申请专利保护范围之内。
本申请所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
Claims (10)
1.一种数据库主键id生成方法,其特征在于,包括:
基于预设的时间维度获取当前的时间戳;
获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符;
读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码;
获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号;
对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。
2.根据权利要求1所述的数据库主键id生成方法,其特征在于,所述获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符的步骤包括:
获取容器对应的容器名称、服务器ip地址和机器码;
将所述容器名称、所述服务器ip地址和所述机器码进行组合后,通过哈希处理生成目标哈希值;
将所述目标哈希值转换为以无符号长整型表示的所述目标容器标识符。
3.根据权利要求1所述的数据库主键id生成方法,其特征在于,所述获取自增序列的步骤包括:
调用jdk中的AtomicInteger原子类;
访问所述AtomicInteger原子类对应的应用程序接口,通过getAndIncrement或incrementAndGet方法获取所述自增序列。
4.根据权利要求1所述的数据库主键id生成方法,其特征在于,所述获取自增序列的步骤还包括:
调用预设的序列自增语句;
获取序列自增需求,所述自增需求中指定有序列自增时的初始序列号、序列间隔和序列最大值;
基于所述序列自增需求配置所述序列自增语句生成自增序列。
5.根据权利要求4所述的数据库主键id生成方法,其特征在于,所述基于所述序列自增需求配置所述序列自增语句生成自增序列的步骤还包括:
读取预设的回滚阈值;
比较所述序列最大值和所述回滚阈值的大小;
若所述序列最大值小于所述回滚阈值,则在所述序列自增语句中配置回滚操作,使序列号达到所述序列最大值后回退至所述初始序列号重新计数。
6.根据权利要求1所述的数据库主键id生成方法,其特征在于,在所述对所述自增序列号与所述运算掩码执行位运算获取目标序列号的步骤之后,所述方法还包括:
将所述时间戳、所述目标容器地址和所述目标序列号存储至区块链中。
7.一种数据库主键id生成装置,其特征在于,包括:
时间戳获取模块,用于基于预设的时间维度获取当前的时间戳;
容器标识获取模块,用于获取容器初始标识符,并将所述容器初始标识符转换为以整数表示的目标容器标识符;
掩码设置模块,用于读取预设的掩码长度,根据所述掩码长度定义一个以整数表示的运算掩码;
序列号计算模块,用于获取自增序列,调用所述自增序列以获取自增序列号,并对所述自增序列号与所述运算掩码执行位运算获取目标序列号;
主键id计算模块,用于对所述时间戳、所述目标容器标识符和所述目标序列号执行位运算,生成目标主键id。
8.根据权利要求7所述的数据库主键id生成装置,其特征在于,所述容器标识获取模块用于:
获取容器对应的容器名称、服务器ip地址和机器码;
将所述容器名称、所述服务器ip地址和所述机器码进行组合后,通过哈希处理生成目标哈希值;
将所述目标哈希值转换为以无符号长整型表示的所述目标容器标识符。
9.一种计算机设备,包括存储器和处理器,其特征在于,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如权利要求1-6中任意一项所述的数据库主键id生成方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1-6中任意一项所述的数据库主键id生成方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011540536.4A CN112632071A (zh) | 2020-12-23 | 2020-12-23 | 数据库主键id生成方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011540536.4A CN112632071A (zh) | 2020-12-23 | 2020-12-23 | 数据库主键id生成方法、装置、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112632071A true CN112632071A (zh) | 2021-04-09 |
Family
ID=75321680
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011540536.4A Pending CN112632071A (zh) | 2020-12-23 | 2020-12-23 | 数据库主键id生成方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112632071A (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113190554A (zh) * | 2021-04-30 | 2021-07-30 | 平安养老保险股份有限公司 | 一种生成主键的方法和分布式系统 |
CN114900497A (zh) * | 2022-05-09 | 2022-08-12 | 上海极豆科技有限公司 | 一种标识序号生成方法、装置、电子设备及存储介质 |
CN116541428A (zh) * | 2023-07-03 | 2023-08-04 | 深圳前海环融联易信息科技服务有限公司 | 一种用于数据库的序列号生成方法、装置、设备及介质 |
CN117251456A (zh) * | 2023-11-16 | 2023-12-19 | 广州市千钧网络科技有限公司 | 一种主键值生成方法、装置、电子设备和存储介质 |
CN117312319A (zh) * | 2023-10-09 | 2023-12-29 | 中科院成都信息技术股份有限公司 | 基于元数据的数据存储方法、装置、设备及存储介质 |
-
2020
- 2020-12-23 CN CN202011540536.4A patent/CN112632071A/zh active Pending
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113190554A (zh) * | 2021-04-30 | 2021-07-30 | 平安养老保险股份有限公司 | 一种生成主键的方法和分布式系统 |
CN114900497A (zh) * | 2022-05-09 | 2022-08-12 | 上海极豆科技有限公司 | 一种标识序号生成方法、装置、电子设备及存储介质 |
CN114900497B (zh) * | 2022-05-09 | 2023-09-26 | 上海极豆科技有限公司 | 一种标识序号生成方法、装置、电子设备及存储介质 |
CN116541428A (zh) * | 2023-07-03 | 2023-08-04 | 深圳前海环融联易信息科技服务有限公司 | 一种用于数据库的序列号生成方法、装置、设备及介质 |
CN116541428B (zh) * | 2023-07-03 | 2023-10-27 | 深圳前海环融联易信息科技服务有限公司 | 一种用于数据库的序列号生成方法、装置、设备及介质 |
CN117312319A (zh) * | 2023-10-09 | 2023-12-29 | 中科院成都信息技术股份有限公司 | 基于元数据的数据存储方法、装置、设备及存储介质 |
CN117251456A (zh) * | 2023-11-16 | 2023-12-19 | 广州市千钧网络科技有限公司 | 一种主键值生成方法、装置、电子设备和存储介质 |
CN117251456B (zh) * | 2023-11-16 | 2024-03-08 | 广州市千钧网络科技有限公司 | 一种主键值生成方法、装置、电子设备和存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112632071A (zh) | 数据库主键id生成方法、装置、设备及存储介质 | |
US20200167344A1 (en) | Method and device for writing service data in block chain system | |
CN110413386B (zh) | 多进程处理方法、装置、终端设备及计算机可读存储介质 | |
CN112507027B (zh) | 基于Kafka的增量数据同步方法、装置、设备及介质 | |
CN107395784B (zh) | 一种批量导入互联网协议ip池的方法和装置 | |
CN111782304B (zh) | 分页加载数据逻辑控制方法、装置、计算机设备及介质 | |
CN112199442B (zh) | 分布式批量下载文件方法、装置、计算机设备及存储介质 | |
WO2022095518A1 (zh) | 接口自动化测试方法、装置、计算机设备及存储介质 | |
CN112380227A (zh) | 基于消息队列的数据同步方法、装置、设备及存储介质 | |
CN112631924A (zh) | 自动化测试方法、装置、计算机设备及存储介质 | |
CN113254445A (zh) | 实时数据存储方法、装置、计算机设备及存储介质 | |
CN111680477A (zh) | 导出电子表格文件的方法、装置、计算机设备及存储介质 | |
CN112631751A (zh) | 任务调度方法、装置、计算机设备及存储介质 | |
CN111475309A (zh) | 一种数据处理方法、装置、区块链服务系统及存储介质 | |
CN112860662A (zh) | 数据血缘关系建立方法、装置、计算机设备及存储介质 | |
CN112965721A (zh) | 基于Android的项目编译方法、装置、计算机设备及存储介质 | |
CN111291084A (zh) | 样本id对齐方法、装置、设备及存储介质 | |
CN108241732B (zh) | 电子装置、信息处理的方法及存储介质 | |
CN115687826A (zh) | 页面刷新方法、装置、计算机设备及存储介质 | |
CN114626352A (zh) | 报表自动化生成方法、装置、计算机设备及存储介质 | |
CN114637672A (zh) | 自动化数据测试方法、装置、计算机设备及存储介质 | |
CN113448960A (zh) | 一种导入表格文件的方法和装置 | |
CN111506644A (zh) | 一种应用数据处理方法、装置和电子设备 | |
CN113194127B (zh) | 一种数据存储方法、数据传输方法及计算设备 | |
CN114218191A (zh) | 系统功能迁移方法、装置、计算机设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |