CN117807090A - 序列值生成方法、装置和设备 - Google Patents

序列值生成方法、装置和设备 Download PDF

Info

Publication number
CN117807090A
CN117807090A CN202311864399.3A CN202311864399A CN117807090A CN 117807090 A CN117807090 A CN 117807090A CN 202311864399 A CN202311864399 A CN 202311864399A CN 117807090 A CN117807090 A CN 117807090A
Authority
CN
China
Prior art keywords
sequence
database
values
memory
information table
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
Application number
CN202311864399.3A
Other languages
English (en)
Inventor
韩金涛
吕光
赵博
张瑜
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Industrial and Commercial Bank of China Ltd ICBC
Original Assignee
Industrial and Commercial Bank of China Ltd ICBC
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Industrial and Commercial Bank of China Ltd ICBC filed Critical Industrial and Commercial Bank of China Ltd ICBC
Priority to CN202311864399.3A priority Critical patent/CN117807090A/zh
Publication of CN117807090A publication Critical patent/CN117807090A/zh
Pending legal-status Critical Current

Links

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本公开的实施例提供了一种序列值生成方法,可以应用于计算机技术领域和大数据技术领域。该方法包括:获取第一数据库中的序列信息表,基于所述第一数据库中的序列信息表,生成第二数据库中的序列信息表。获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量。基于内存容量,生成序列缓存值n。对所述多个第一序列值进行处理,生成多个第二序列值。顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。本公开还提供了一种序列值生成装置、计算设备、介质和程序产品。

Description

序列值生成方法、装置和设备
技术领域
本公开涉及计算机技术领域,具体涉及大数据技术领域,特别是涉及一种序列值生成方法、装置、设备、介质和程序产品。
背景技术
为了保证数据的稳定性和可靠性,包括银行在内的企业对数据库转型迁移的需日渐增高,银行在数据转型迁移的过程中,不仅要保障数据的完整性和安全性,还需要考虑业务的连续性和硬件设施的适用性,以确保迁移过程的平滑过渡。
目前在两个不同数据库的数据迁移过程中,容易出现由于两个不同数据库的存储逻辑不同,造成数据丢失以及数据损坏的情况,并且在迁移后的新数据库在内存中生成序列值时,由于新数据库的缓存值一般都是由新数据库配置生成的,容易出现缓存值与内存容量不匹配造成内存浪费或内存过载的情况。
发明内容
鉴于上述问题,本公开提供了一种序列值生成方法、装置、设备、介质和程序产品。
根据本公开的第一个方面提供了一种序列值生成方法,其特征在于,该方法包括:
获取第一数据库中的序列信息表;
基于所述第一数据库中的序列信息表,生成第二数据库中的序列信息表,其中,所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述第二数据库中的序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值;
获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量;
基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数;
对所述多个第一序列值进行处理,生成多个第二序列值,其中,所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集;以及
顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。
根据本公开实施例,其特征在于,基于所述第一数据库中的序列信息表,生成所述第二数据库中的序列信息表,包括:
查询所述第一数据库中的序列信息表的序列定义;
对所述第一数据库中的序列信息表的序列定义进行处理,生成第二数据库的序列定义格式;以及
根据所述第二数据库的序列定义格式,生成所述第二数据库中的序列信息表。
根据本公开实施例,其特征在于,还包括:
在对所述多个第一序列值进行处理,生成多个第二序列值之前,对所述第二数据库中的序列信息表进行加锁;以及
在顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值之后,对被加锁的所述第二数据库中的序列信息表进行释放锁。
根据本公开实施例,其特征在于,对所述多个第一序列值进行处理,生成多个第二序列值,包括:
检测内存列表是否为空;以及
如果所述内存列表为空,则直接复制多个第一序列值,生成多个第二序列值。
根据本公开实施例,其特征在于,对所述多个第一序列值进行处理,生成多个第二序列值,还包括:
如果所述内存列表不为空,则检测内存中是否存在所述序列名称;
如果存在所述序列名称,则检测内存中是否存在与所述序列名称一一对应的序列信息中的序列值;以及
如果不存在与所述序列名称一一对应的序列信息中的序列值,则更新所述多个第一序列值,生成多个第二序列值。
根据本公开实施例,其特征在于,所述序列信息包括:序列最大值和序列最小值,所述更新所述多个第一序列值,生成多个第二序列值,包括:
将所述多个第一序列值中的每个序列值分别与所述序列缓存值n求和,生成更新后的多个第一序列值;以及
获取所述更新后的多个第一序列值中的大于等于所述序列最小值并且小于等于所述序列最大值的序列值,生成多个第二序列值。
根据本公开的第二个方面提供了一种序列值生成装置,其特征在于,该装置包括:
第一获取模块,用于获取第一数据库中的序列信息表;
第一生成模块,用于基于所述第一数据库中的序列信息表,生成所述第二数据库中的序列信息表,其中,所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值;
第二获取模块,用于获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量;
第二生成模块,用于基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数;
第三生成模块,用于对所述多个第一序列值进行处理,生成多个第二序列值,其中,所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集;以及
第四生成模块,用于顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。
根据本公开实施例,其特征在于,所述第一生成模块,包括:
查询模块,用于查询所述第一数据库中的序列信息表的序列定义。
第五生成模块,用于对所述第一数据库中的序列信息表的序列定义进行处理,生成第二数据库的序列定义格式。
第六生成模块,用于根据所述第二数据库的序列定义格式,生成所述第二数据库中的序列信息表。
根据本公开实施例,其特征在于,所述第三生成模块,包括:
第一检测模块,用于检测内存列表是否为空。
第七生成模块,用于如果所述内存列表为空,则直接复制多个第一序列值,生成多个第二序列值。
第二检测模块,用于如果所述内存列表不为空,则检测内存中是否存在所述序列名称。
第三检测模块,用于如果存在所述序列名称,则检测内存中是否存在与所述序列名称一一对应的序列信息中的序列值。
第八生成模块,用于如果不存在与所述序列名称一一对应的序列信息中的序列值,则更新所述多个第一序列值,生成多个第二序列值。
根据本公开实施例,其特征在于,所述第八生成模块,包括:
第九生成模块,用于将所述多个第一序列值中的每个序列值分别与所述序列缓存值n求和,生成更新后的多个第一序列值。
第十生成模块,用于获取所述更新后的多个第一序列值中的大于等于所述序列最小值并且小于等于所述序列最大值的序列值,生成多个第二序列值。
根据本公开的第三方面提供了一种电子设备,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
其中,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器执行上述序列值生成方法。
根据本公开的第四方面提供了一种计算机可读存储介质,其上存储有可执行指令,该指令被处理器执行时使处理器执行上述序列值生成方法。
根据本公开的第五方面还提供了一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时实现上述序列值生成方法。
通过第一数据库中的序列信息表生成第二数据库中的序列信息表,可以在数据库转型迁移的过程中,使第一数据库中的存储过程逻辑更好地适应第二数据库,降低了数据库迁移的风险;通过基于内存容量在内存中生成n个目标序列值的技术手段,实现了使计算机内存得到充分的利用的技术效果,避免内存利用率太低造成内存的浪费和内存使用太过饱和造成风险的技术问题。
附图说明
通过以下参照附图对本公开实施例的描述,本公开的上述内容以及其他目的、特征和优点将更为清楚,在附图中:
图1示意性示出了根据本公开实施例的序列值生成方法和装置的应用场景图;
图2示意性示出了根据本公开实施例的序列值生成方法的流程图;
图3示意性示出了根据本公开实施例的序列值生成方法中生成第二数据库中的序列信息表的流程图;
图4示意性示出了根据本公开实施例的序列值生成方法中生成多个第二序列值的流程图;
图5示意性示出了根据本公开实施例的序列值生成方法中更新多个第一序列值的流程图;
图6示意性示出了根据本公开实施例的序列值生成装置的结构框图;
图7示意性示出了根据本公开实施例的序列值生成装置中第一生成模块的结构框图;
图8示意性示出了根据本公开实施例的序列值生成装置中第三生成模块的结构框图;
图9示意性示出了根据本公开实施例的序列值生成装置中第八生成模块的结构框图;
图10示意性示出了根据本公开实施例的适于实现序列值生成方法的电子设备的方框图。
具体实施方式
以下,将参照附图来描述本公开的实施例。但是应该理解,这些描述只是示例性的,而并非要限制本公开的范围。在下面的详细描述中,为便于解释,阐述了许多具体的细节以提供对本公开实施例的全面理解。然而,明显地,一个或多个实施例在没有这些具体细节的情况下也可以被实施。此外,在以下说明中,省略了对公知结构和技术的描述,以避免不必要地混淆本公开的概念。
在此使用的术语仅仅是为了描述具体实施例,而并非意在限制本公开。在此使用的术语“包括”、“包含”等表明了所述特征、步骤、操作和/或部件的存在,但是并不排除存在或添加一个或多个其他特征、步骤、操作或部件。
在此使用的所有术语(包括技术和科学术语)具有本领域技术人员通常所理解的含义,除非另外定义。应注意,这里使用的术语应解释为具有与本说明书的上下文相一致的含义,而不应以理想化或过于刻板的方式来解释。
在使用类似于“A、B和C等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有A、B和C中至少一个的系统”应包括但不限于单独具有A、单独具有B、单独具有C、具有A和B、具有A和C、具有B和C、和/或具有A、B、C的系统等)。
附图中示出了一些方框图和/或流程图。应理解,方框图和/或流程图中的一些方框或其组合可以由计算机程序指令来实现。这些计算机程序指令可以提供给通用计算机、专用计算机或其他可编程控制装置的处理器,从而这些指令在由该处理器执行时可以创建用于实现这些方框图和/或流程图中所说明的功能/操作的装置。
首先,对本文中出现的技术术语作如下解释:
共享锁:也称读锁,允许多个事务同时读取同一资源,但不允许其他事务对该资源进行修改。
排他锁:也成写锁,只允许一个事务对资源进行修改,其他事务无法读取或修改该资源。
Redis:是一个高性能的key-value数据库,具有很多显著地特性。它基于内存运行,支持数据的持久化,备份和原子性操作。
SequenceName:是数据库中序列的名称,这是指定数据库中已经存在的序列的方式。在创建数据库序列时,需要为序列命名,以便后续的使用和管理。
CurBo:是一个数据对象,它可能是一个表、视图、存储过程或函数。这里表示seqname值相关信息。
MySQLSequenceFactory:是一个用于生成数据库序列的工厂类。
getseqinit方法通常用于获取序列的初始化值。
getNextVal方法通常用于获取序列的下一个值。
本公开的实施例提供了一种序列值生成方法,该方法包括:获取第一数据库中的序列信息表,基于所述第一数据库中的序列信息表,生成第二数据库中的序列信息表。其中,所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述第二数据库中的序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值。获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量。基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数。对所述多个第一序列值进行处理,生成多个第二序列值,其中,所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集。顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。
通过第一数据库中的序列信息表生成第二数据库中的序列信息表,可以在数据库转型迁移的过程中,使第一数据库中的存储过程逻辑更好地适应第二数据库,降低了数据库迁移的风险;通过基于内存容量在内存中生成n个目标序列值的技术手段,实现了使计算机内存得到充分的利用的技术效果,避免内存利用率太低造成内存的浪费和内存使用太过饱和造成风险的技术问题。
图1示意性示出了根据本公开实施例的序列值生成方法和装置的应用场景图。需要注意的是,图1所示仅为可以应用本公开实施例的场景的示例,以帮助本领域技术人员理解本公开的技术内容,但并不意味着本公开实施例不可以用于其他设备、系统、环境或场景。
如图1所示,根据该实施例的应用场景100可以包括多个应用终端和应用服务器。例如,多个应用终端包括应用终端101、应用终端102、应用终端103等等。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用应用终端设备101、102、103通过网络104与应用服务器105交互,以接收或发送消息等。应用终端设备101、102、103上可以安装有各种应用程序,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对用户利用终端设备101、102、103所浏览的网站提供支持的后台管理服务器(仅为示例)。后台管理服务器可以对接收到的用户请求等数据进行分析等处理,并将处理结果(例如根据用户请求获取或生成的网页、信息、或数据等)反馈给终端设备。
需要说明的是,本公开实施例所提供的序列值生成方法一般可以由服务器105执行。相应地,本公开实施例所提供的序列值生成装置一般可以设置于服务器105中。本公开实施例所提供的序列值生成方法也可以由不同于服务器105且能够与终端设备101、102、103和/或服务器105通信的服务器或服务器集群执行。相应地,本公开实施例所提供的序列值生成装置也可以设置于不同于服务器105且能够与终端设备101、102、103和/或服务器105通信的服务器或服务器集群中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
以下将基于图1描述的场景,通过图2~图5对公开实施例的序列值生成方法进行详细描述。需要注意的是,上述应用场景仅是为了便于理解本公开的精神和原理而示出,本公开的实施方式在此方面不受任何限制。相反,本公开的实施方式可以应用于适用的任何场景。
图2示意性示出了根据本公开实施例应用于客户端的序列值生成方法的流程图。
如图2所示,该方法200包括步骤S201~S208。
步骤S201,获取第一数据库中的序列信息表。
例如,第一数据库可以是Orca1数据库,获取Orcal数据库中的序列信息表。
步骤S202,基于所述第一数据库中的序列信息表,生成第二数据库中的序列信息表。
所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述第二数据库中的序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值、序列最大值、序列最小值。
图3示意性示出了根据本公开实施例的序列值生成方法中生成第二数据库中的序列信息表的流程图。
如图3所示,该方法300包括步骤S301~S303。
步骤S301,查询所述第一数据库中的序列信息表的序列定义。
例如,可以查询Orcal数据库中的序列信息表的序列定义。
步骤S302,对所述第一数据库中的序列信息表的序列定义进行处理,生成第二数据库的序列定义格式。
例如,第二数据库可以是MySQL数据库,可以根据Orcal数据库中的序列信息表的序列定义构建MySQL的序列定义格式。
步骤S303,根据所述第二数据库的序列定义格式,生成所述第二数据库中的序列信息表。
例如,将Orcal数据库迁移到MySQL数据库并生成序列信息表的具体过程为:确保已经安装了Orcal数据库和MySQL数据库客户端的情况下,将Orcal数据库导出SQL文件。查询sql文件中的序列定义,并根据Orcal数据库的序列定义格式修改为MySQL数据库的序列定义格式,然后检查MySQL数据库的表结构和序列是否与Orcal数据库一致,如果一致,则生成序列信息表。
通过第一数据库中的序列信息表的序列定义生成第二数据库的序列定义格式,可以使在第一数据库转型第二数据库的过程中,更加平滑,避免风险。
返回参照图2,在步骤S203中,获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量。
步骤S204,基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数。
步骤S205,对所述第二数据库中的序列信息表进行加锁。
例如,可以创建一个Lock对象对第二数据库中的序列信息表进行加锁,这里的加锁操作可以是共享锁也可以是排他锁。
步骤S206,对所述多个第一序列值进行处理,生成多个第二序列值。
所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集。
图4示意性示出了根据本公开实施例的序列值生成方法中生成多个第二序列值的流程图。
如图4所示,该方法400包括步骤S401~S405。
步骤S401,检测内存列表是否为空。
例如,可以检测内存中的Redis的列表Bolist是否为空。
步骤S402,如果所述内存列表为空,则直接复制多个第一序列值,生成多个第二序列值。
例如,如果内存中的Redis的列表Bolist为空,则证明该内存中是第一次存储序列,这时的多个第一序列值与多个第二序列值相同,可以直接复制多个第一序列值生成多个第二序列值。
通过检测内存中的序列值是否为空,可以判断内存中是否为初次生成目标序列值,确定为内存中是初次生成目标序列值,便可直接复制多个第一序列值,节约了计算机资源。
步骤S403,如果所述内存列表不为空,则检测内存中是否存在所述序列名称。
例如,内存中的Redis的列表Bolist不为空,可以检测内存中是否存在SequenceName。
步骤S404,如果存在所述序列名称,则检测内存中是否存在与所述序列名称一一对应的序列信息中的序列值。
例如,如果内存中存在SequenceName,则判断内存中是否存在与SequenceName相对应的序列信息中的序列值。其中,与SequenceName相对应的序列信息可以用CurBo表示。
步骤S405,如果不存在与所述序列名称一一对应的序列信息中的序列值,则更新所述多个第一序列值,生成多个第二序列值。
图5示意性示出了根据本公开实施例的序列值生成方法中更新多个第一序列值的流程图。
如图5所示,该方法500包括步骤S502~S502。
步骤S501,将所述多个第一序列值中的每个序列值分别与所述序列缓存值n求和,生成更新后的多个第一序列值。
步骤S502,获取所述更新后的多个第一序列值中的大于等于所述序列最小值并且小于等于所述序列最大值的序列值,生成多个第二序列值。
通过对多个第一序列值进行更新和限定,可以选择出多个第一序列值中未被使用的序列值,生成第二序列值,提高了生成序列值的准确性。通过确定为内存中并非初次生成目标序列值后判断内存中的序列值是否被取空,可以检测内存中序列值的状态,避免了交易序列值获取错误,造成风险。
返回参照图2,在步骤S207中,顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。
步骤S208,对被加锁的所述第二数据库中的序列信息表进行释放锁。
例如,在内存中生成n个目标序列值后,可以调用Lock对象的释放资源方法释放锁。
通过加锁和释放锁操作,可以使在内存中生成n个目标序列值免受其他进程的干扰,降低了风险。
本公开实施例可以在MySQL数据库新建表,此表主要存储序列的相关信息,序列的相关信息包括:序列名称、序列值、序列最大值、序列最小值、创建时间和修改时间等。然后在容器或者服务器重启时,通过操作表获取序列相关信息,并将序列的相关信息缓存存储到redis中。具体包括:初始化缓存全部序列值到内存中,在容器/服务器启动时,调用init方法,此方法会调用查询数据库查询表,获取表中所有数据的列表,循环遍历列表,在循环中将列表中所有的记录均调用getseqinit方法,getseqinit方法用于获取序列的初始化值。根据主键查询表,并将查询到的当前序列值作为新值更新到表。最后把查询到的数据存放到内存中,以备后续交易程序使用。最后应用在使用序列时,从内存中直接获取,如果序列使用完,重新获取序列值并缓存到Redis中,具体包括:调用MySQLSequenceFactory的getNextVal方法,先判断内存中是否存在seqname值相关信息,如果存在直接返回最大值和最小值,如果不存在,则调用getseqinit方法,获取seqname相关信息,并将该序列最大和最小值存放到内存中,返回当前序列值给调用方。该方法可以在Orcal数据库转型MySQL数据库的过程中对于序列相关的交易提供一种平滑过渡。
图6示意性示出了根据本公开实施例的序列值生成装置的结构框图。
如图6所示,序列值生成装置600包括:第一获取模块601、第一生成模块602、第二获取模块603、第二生成模块604、加锁模块605、第三生成模块606、第四生成模块607和释放锁模块608。
第一获取模块601,用于获取第一数据库中的序列信息表。在一实施例中,第一获取模块601可以用于执行前文描述的步骤S201,在此不再赘述。
第一生成模块602,用于基于所述第一数据库中的序列信息表,生成第二数据库中的序列信息表,其中,所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述第二数据库中的序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值。在一实施例中,第一生成模块602可以用于执行前文描述的步骤S202。
图7示意性示出了根据本公开实施例的序列值生成装置中第一生成模块的结构框图。
如图7所示,第一生成模块包括:查询模块701、第五生成模块702和第六生成模块703。
查询模块701,用于查询所述第一数据库中的序列信息表的序列定义。在一实施例中,查询模块701可以用于执行前文描述的步骤S301,在此不再赘述。
第五生成模块702,用于对所述第一数据库中的序列信息表的序列定义进行处理,生成第二数据库的序列定义格式。在一实施例中,第五生成模块702可以用于执行前文描述的步骤S302,在此不再赘述。
第六生成模块703,用于根据所述第二数据库的序列定义格式,生成所述第二数据库中的序列信息表。在一实施例中,第六生成模块703可以用于执行前文描述的步骤S303,在此不再赘述。
返回参照图6,第二获取模块603,用于获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量。在一实施例中,第二获取模块603可以用于执行前文描述的步骤S203,在此不再赘述。
第二生成模块604,用于基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数。在一实施例中,第二生成模块604可以用于执行前文描述的步骤S204,在此不再赘述。
加锁模块605,用于对所述第二数据库中的序列信息表进行加锁。在一实施例中,加锁模块605可以用于执行前文描述的步骤S205,在此不再赘述。
第三生成模块606,用于对所述多个第一序列值进行处理,生成多个第二序列值,其中,所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集。在一实施例中,第三生成模块606可以用于执行前文描述的步骤S206。
图8示意性示出了根据本公开实施例的序列值生成装置中第三生成模块的结构框图。
如图8所示,第三生成模块包括:第一检测模块801、第七生成模块802、第二检测模块803、第三检测模块804和第八生成模块805。
第一检测模块801,用于检测内存列表是否为空。在一实施例中,第一检测模块801可以用于执行前文描述的步骤S401,在此不再赘述。
第七生成模块802,用于如果所述内存内存列表为空,则直接复制多个第一序列值,生成多个第二序列值。在一实施例中,第七生成模块802可以用于执行前文描述的步骤S402,在此不再赘述。
第二检测模块803,用于如果所述内存列表不为空,则检测内存中是否存在所述序列名称。在一实施例中,第二检测模块803可以用于执行前文描述的步骤S403,在此不再赘述。
第三检测模块804,用于如果存在所述序列名称,则检测内存中是否存在与所述序列名称一一对应的序列信息中的序列值。在一实施例中,第三检测模块804可以用于执行前文描述的步骤S404,在此不再赘述。
第八生成模块805,用于如果不存在与所述序列名称一一对应的序列信息中的序列值,则更新所述多个第一序列值,生成多个第二序列值。在一实施例中,第八生成模块805可以用于执行前文描述的步骤S405。
图9示意性示出了根据本公开实施例的序列值生成装置中第八生成模块的结构框图。
如图9所示,第八生成模块805包括第九生成模块901和第十生成模块902。
第九生成模块901,用于将所述多个第一序列值中的每个序列值分别与所述序列缓存值n求和,生成更新后的多个第一序列值。在一实施例中,第九生成模块901可以用于执行前文描述的步骤S501,在此不再赘述。
第十生成模块902,用于获取所述更新后的多个第一序列值中的大于等于所述序列最小值并且小于等于所述序列最大值的序列值,生成多个第二序列值。在一实施例中,第十生成模块902可以用于执行前文描述的步骤S502,在此不再赘述。
返回参照图6,第四生成模块607,用于顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。在一实施例中,第四生成模块607可以用于执行前文描述的步骤S207,在此不再赘述。
释放锁模块608,用于对被加锁的所述第二数据库中的序列信息表进行释放锁。在一实施例中,释放锁模块608可以用于执行前文描述的步骤S208,在此不再赘述。
根据本公开的实施例,第一获取模块601、第一生成模块602、第二获取模块603、第二生成模块604、加锁模块605、第三生成模块606、第四生成模块607和释放锁模块608中的任意多个模块可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本公开的实施例,第一获取模块601、第一生成模块602、第二获取模块603、第二生成模块604、加锁模块605、第三生成模块606、第四生成模块607和释放锁模块608中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以通过对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,第一获取模块601、第一生成模块602、第二获取模块603、第二生成模块604、加锁模块605、第三生成模块606、第四生成模块607和释放锁模块608中的至少一个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。
图10示意性示出了根据本公开实施例的适于实现序列值生成方法的电子设备的方框图。
如图10所示,根据本公开实施例的电子设备1000包括处理器1001,其可以根据存储在只读存储器(ROM)1002中的程序或者从存储部分1008加载到随机访问存储器(RAM)1003中的程序而执行各种适当的动作和处理。处理器1001例如可以包括通用微处理器(例如CPU)、指令集处理器和/或相关芯片组和/或专用微处理器(例如,专用集成电路(ASIC))等等。处理器1001还可以包括用于缓存用途的板载存储器。处理器1001可以包括用于执行根据本公开实施例的方法流程的不同动作的单一处理单元或者是多个处理单元。
在RAM 1003中,存储有电子设备1000操作所需的各种程序和数据。处理器1001、ROM 1002以及RAM1003通过总线1004彼此相连。处理器1001通过执行ROM1002和/或RAM1003中的程序来执行根据本公开实施例的方法流程的各种操作。需要注意,所述程序也可以存储在除ROM 1002和RAM 1003以外的一个或多个存储器中。处理器1001也可以通过执行存储在所述一个或多个存储器中的程序来执行根据本公开实施例的方法流程的各种操作。
根据本公开的实施例,电子设备1000还可以包括输入/输出(I/O)接口1005,输入/输出(I/O)接口1005也连接至总线1004。电子设备1000还可以包括连接至I/O接口1005的以下部件中的一项或多项:包括键盘、鼠标等的输入部分1006;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分1007;包括硬盘等的存储部分1008;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分1009。通信部分1009经由诸如因特网的网络执行通信处理。驱动器1010也根据需要连接至I/O接口1005。可拆卸介质1011,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器1010上,以便于从其上读出的计算机程序根据需要被安装入存储部分1008。
本公开还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施例中描述的设备/装置/系统中所包含的;也可以是单独存在,而未装配入该设备/装置/系统中。上述计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被执行时,实现根据本公开实施例的方法。
根据本公开的实施例,计算机可读存储介质可以是非易失性的计算机可读存储介质,例如可以包括但不限于:便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。例如,根据本公开的实施例,计算机可读存储介质可以包括上文描述的ROM1002和/或RAM 1003和/或ROM1002和RAM1003以外的一个或多个存储器。
本公开的实施例还包括一种计算机程序产品,其包括计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。当计算机程序产品在计算机系统中运行时,该程序代码用于使计算机系统实现本公开实施例所提供的序列值生成方法。
在该计算机程序被处理器1001执行时执行本公开实施例的系统/装置中限定的上述功能。根据本公开的实施例,上文描述的系统、装置、模块、单元等可以通过计算机程序模块来实现。
在一种实施例中,该计算机程序可以依托于光存储器件、磁存储器件等有形存储介质。在另一种实施例中,该计算机程序也可以在网络介质上以信号的形式进行传输、分发,并通过通信部分1009被下载和安装,和/或从可拆卸介质1011被安装。该计算机程序包含的程序代码可以用任何适当的网络介质传输,包括但不限于:无线、有线等等,或者上述的任意合适的组合。
在这样的实施例中,该计算机程序可以通过通信部分1009从网络上被下载和安装,和/或从可拆卸介质1011被安装。在该计算机程序被处理器1001执行时,执行本公开实施例的系统中限定的上述功能。根据本公开的实施例,上文描述的系统、设备、装置、模块、单元等可以通过计算机程序模块来实现。
根据本公开的实施例,可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例提供的计算机程序的程序代码,具体地,可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。程序设计语言包括但不限于诸如Java,C++,python,“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
本领域技术人员可以理解,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合或/或结合,即使这样的组合或结合没有明确记载于本公开中。特别地,在不脱离本公开精神和教导的情况下,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合和/或结合。所有这些组合和/或结合均落入本公开的范围。
以上对本公开的实施例进行了描述。但是,这些实施例仅仅是为了说明的目的,而并非为了限制本公开的范围。尽管在以上分别描述了各实施例,但是这并不意味着各个实施例中的措施不能有利地结合使用。本公开的范围由所附权利要求及其等同物限定。不脱离本公开的范围,本领域技术人员可以做出多种替代和修改,这些替代和修改都应落在本公开的范围之内。

Claims (10)

1.一种序列值生成方法,其特征在于,该方法包括:
获取第一数据库中的序列信息表;
基于所述第一数据库中的序列信息表,生成第二数据库中的序列信息表,其中,所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述第二数据库中的序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值;
获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量;
基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数;
对所述多个第一序列值进行处理,生成多个第二序列值,其中,所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集;以及
顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。
2.根据权利要求1所述的方法,其特征在于,基于所述第一数据库中的序列信息表,生成所述第二数据库中的序列信息表,包括:
查询所述第一数据库中的序列信息表的序列定义;
对所述第一数据库中的序列信息表的序列定义进行处理,生成第二数据库的序列定义格式;以及
根据所述第二数据库的序列定义格式,生成所述第二数据库中的序列信息表。
3.根据权利要求1所述的方法,其特征在于,还包括:
在对所述多个第一序列值进行处理,生成多个第二序列值之前,对所述第二数据库中的序列信息表进行加锁;以及
在顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值之后,对被加锁的所述第二数据库中的序列信息表进行释放锁。
4.根据权利要求1所述的方法,其特征在于,对所述多个第一序列值进行处理,生成多个第二序列值,包括:
检测内存列表是否为空;以及
如果所述内存列表为空,则直接复制多个第一序列值,生成多个第二序列值。
5.根据权利要求4所述的方法,其特征在于,对所述多个第一序列值进行处理,生成多个第二序列值,还包括:
如果所述内存列表不为空,则检测内存中是否存在所述序列名称;
如果存在所述序列名称,则检测内存中是否存在与所述序列名称一一对应的序列信息中的序列值;以及
如果不存在与所述序列名称一一对应的序列信息中的序列值,则更新所述多个第一序列值,生成多个第二序列值。
6.根据权利要求5所述的方法,其特征在于,所述序列信息包括:序列最大值和序列最小值,所述更新所述多个第一序列值,生成多个第二序列值,包括:
将所述多个第一序列值中的每个序列值分别与所述序列缓存值n求和,生成更新后的多个第一序列值;以及
获取所述更新后的多个第一序列值中的大于等于所述序列最小值并且小于等于所述序列最大值的序列值,生成多个第二序列值。
7.一种序列值生成装置,其特征在于,该装置包括:
第一获取模块,用于获取第一数据库中的序列信息表;
第一生成模块,用于基于所述第一数据库中的序列信息表,生成所述第二数据库中的序列信息表,其中,所述第一数据库中的序列信息表和所述第二数据库中的序列信息表的结构不同,所述序列信息表包括:序列名称和序列信息,所述序列名称与所述序列信息一一对应,所述序列信息包括:多个第一序列值;
第二获取模块,用于获取所述第二数据库的配置内存信息,所述配置内存信息包括内存容量;
第二生成模块,用于基于内存容量,生成序列缓存值n,其中,n大于等于1且n为整数;
第三生成模块,用于对所述多个第一序列值进行处理,生成多个第二序列值,其中,所述多个第二序列值形成的集合是所述多个第一序列值形成的集合的子集;以及
第四生成模块,用于顺序获取所述多个第二序列值中的前n个第二序列值到内存中,在内存中生成n个目标序列值。
8.一种电子设备,包括:
一个或处理器;
存储装置,用于存储一个或程序,
其中,当所述一个或程序被所述一个或处理器执行时,使得所述一个或处理器执行如权利要求1~6中任意一项所述的方法。
9.一种计算机可读存储介质,其上存储有可执行指令,该指令被处理器执行时使处理器执行如权利要求1~6中任意一项所述的方法。
10.一种计算机程序产品,包括计算机程序,所述计算机程序被处理器执行时实现根据权利要求1~6中任一项所述的方法。
CN202311864399.3A 2023-12-29 2023-12-29 序列值生成方法、装置和设备 Pending CN117807090A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311864399.3A CN117807090A (zh) 2023-12-29 2023-12-29 序列值生成方法、装置和设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311864399.3A CN117807090A (zh) 2023-12-29 2023-12-29 序列值生成方法、装置和设备

Publications (1)

Publication Number Publication Date
CN117807090A true CN117807090A (zh) 2024-04-02

Family

ID=90429501

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311864399.3A Pending CN117807090A (zh) 2023-12-29 2023-12-29 序列值生成方法、装置和设备

Country Status (1)

Country Link
CN (1) CN117807090A (zh)

Similar Documents

Publication Publication Date Title
CN111427701A (zh) 一种工作流引擎系统和业务处理方法
CN110109983B (zh) 一种操作Redis数据库的方法和装置
CN114281803A (zh) 数据迁移方法、装置、设备、介质和程序产品
CN113282589A (zh) 一种数据获取方法和装置
US20190258736A1 (en) Dynamic Execution of ETL Jobs Without Metadata Repository
CN116069725A (zh) 文件迁移方法、装置、设备、介质和程序产品
CN117807090A (zh) 序列值生成方法、装置和设备
CN112506781B (zh) 测试监控方法、装置、电子设备、存储介质及程序产品
CN115098469A (zh) 数据库迁移方法及装置、电子设备和可读存储介质
CN116503005A (zh) 流程动态修改方法、装置、系统及存储介质
CN113986833A (zh) 文件合并方法、系统、计算机系统及存储介质
CN112068814A (zh) 可执行文件的生成方法、装置、系统及介质
CN114268558B (zh) 监控图的生成方法、装置、设备、介质
CN115484149B (zh) 网络切换方法、网络切换装置、电子设备及存储介质
CN113574518A (zh) 用于减少高速缓存内存占用的高速缓存对象的内存式规范化
CN115826934B (zh) 一种应用开发系统和方法
CN110262756B (zh) 用于缓存数据的方法和装置
US12001458B2 (en) Multi-cloud object store access
US20210096763A1 (en) Method, device, and computer program product for managing storage system
WO2023193682A1 (en) Local arrangement of remote deployment
CN114625347A (zh) 存储系统sdk的对接方法、装置、设备和存储介质
CN114490891A (zh) 数据处理方法、装置、设备、介质和程序产品
CN117914870A (zh) 数据查询方法、装置、电子设备、介质和程序产品
CN113760321A (zh) 一种视图更新方法、装置、电子设备及存储介质
CN117193754A (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