CN114201504A - 一种信息获取方法、装置、电子设备及存储介质 - Google Patents
一种信息获取方法、装置、电子设备及存储介质 Download PDFInfo
- Publication number
- CN114201504A CN114201504A CN202111350121.5A CN202111350121A CN114201504A CN 114201504 A CN114201504 A CN 114201504A CN 202111350121 A CN202111350121 A CN 202111350121A CN 114201504 A CN114201504 A CN 114201504A
- Authority
- CN
- China
- Prior art keywords
- file
- mapping file
- original
- extended
- operation statement
- 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
- 238000000034 method Methods 0.000 title claims abstract description 41
- 238000013507 mapping Methods 0.000 claims abstract description 172
- 238000004590 computer program Methods 0.000 claims description 9
- 238000012986 modification Methods 0.000 claims description 8
- 230000004048 modification Effects 0.000 claims description 8
- 230000002411 adverse Effects 0.000 abstract description 2
- 230000000694 effects Effects 0.000 abstract description 2
- 238000004891 communication Methods 0.000 description 11
- 238000012545 processing Methods 0.000 description 10
- 238000010586 diagram Methods 0.000 description 6
- 238000005516 engineering process Methods 0.000 description 6
- 230000006870 function Effects 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 4
- 230000002688 persistence Effects 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 230000008859 change Effects 0.000 description 3
- 230000003993 interaction Effects 0.000 description 3
- 230000002085 persistent effect Effects 0.000 description 3
- 230000001133 acceleration Effects 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 238000013473 artificial intelligence Methods 0.000 description 1
- 230000003190 augmentative effect Effects 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000011217 control strategy Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000012217 deletion Methods 0.000 description 1
- 230000037430 deletion Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000007781 pre-processing Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
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/24—Querying
-
- 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/25—Integrating or interfacing systems involving database management systems
-
- 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/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/289—Object oriented databases
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computational Linguistics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本公开关于一种信息获取方法、装置、电子设备及存储介质,包括:获取操作请求,操作请求包括操作语句的标识和执行参数;基于扩展映射文件确定标识对应的目标操作语句,扩展映射文件的命名空间和原始映射文件的命名空间相同;原始映射文件的命名空间基于扩展映射文件的命名空间修改得到,基于目标操作语句获取执行参数的信息。本申请实施例中,扩展映射文件和原始映射文件的相同的命名空间可以用于保证扩展映射文件引用原始映射文件中的配置信息和接口,但是扩展映射文件引用原始映射文件之间是独立的,不会受到原始映射文件更新导致的不良影响。
Description
技术领域
本公开涉及互联网技术领域,尤其涉及一种信息获取方法、装置、电子设备及存储介质。
背景技术
在Mybatis数据库框架中,利用生成器基于数据库中的表结构可以生成数据库表对应的原始映射文件,利用上述原始映射文件可以生成了常用的一些数据库表的增删改查操作。
当为了满足用户的需求,需要添加一些非常用的操作时,通常可以在原始映射文件中定义非常用的操作对应的操作语句,然而,当表结构发生变化的时候,会基于变化的表结构生成新的原始映射文件,这就会导致新的原始映射文件覆盖掉原来的原始映射文件,从而把定义的非常用的操作对应的操作语句覆盖掉。
发明内容
本公开提供一种信息获取方法、装置、电子设备及存储介质,本公开的技术方案如下:
根据本公开实施例的第一方面,提供一种信息获取方法,包括:
获取操作请求;操作请求包括操作语句的标识和执行参数;
基于扩展映射文件确定标识对应的目标操作语句;扩展映射文件的命名空间和原始映射文件的命名空间相同;原始映射文件的命名空间基于扩展映射文件的命名空间修改得到;
基于目标操作语句获取执行参数的信息。
在一些可能的实施例中,基于扩展映射文件确定标识对应的目标操作语句之前,还包括:
基于表结构生成原始映射文件;原始映射文件包括原始配置文件和原始接口文件;原始配置文件包括第一操作语句;原始接口文件包括第一接口;
生成扩展映射文件;
将原始映射文件的命名空间修改为扩展映射文件的命名空间;
生成扩展映射文件中的扩展配置文件和扩展接口文件;
其中,扩展映射文件和原始映射文件相同的命名空间用于保证扩展映射文件引用原始映射文件的第一操作语句和第一接口。
在一些可能的实施例中,方法还包括:
在扩展配置文件中定义第二操作语句,得到更新后的扩展配置文件;
在扩展接口文件中定义第二接口,得到更新后的扩展接口文件;
基于更新后的扩展配置文件和更新后的扩展接口文件得到更新后的扩展映射文件。
在一些可能的实施例中,第二操作语句对应的操作包括多表联合操作或单表非基础操作。
在一些可能的实施例中,基于扩展映射文件确定标识对应的目标操作语句包括:
利用扩展映射文件中的扩展配置文件引用原始配置文件,确定标识对应的至少一个第一操作语句为目标操作语句。
在一些可能的实施例中,基于扩展映射文件确定标识对应的目标操作语句包括:
基于扩展映射文件生成代理对象;
基于代理对象确定标识对应的目标操作语句。
在一些可能的实施例中,信息获取方法应用于Mybatis数据库持久层框架。
根据本公开实施例的第二方面,提供一种信息获取装置,包括:
获取模块,被配置为执行获取操作请求;操作请求包括操作语句的标识和执行参数;
操作语句确定模块,被配置为执行基于扩展映射文件确定标识对应的目标操作语句;扩展映射文件的命名空间和原始映射文件的命名空间相同;原始映射文件的命名空间基于扩展映射文件的命名空间修改得到;
信息获取模块,被配置为执行基于目标操作语句获取执行参数的信息。
在一些可能的实施例中,装置还包括:
第一文件生成模块,被配置为执行基于表结构生成原始映射文件;原始映射文件包括原始配置文件和原始接口文件;原始配置文件包括第一操作语句;原始接口文件包括第一接口;
第二文件生成模块,被配置为执行生成扩展映射文件;
修改模块,被配置为执行将原始映射文件的命名空间修改为扩展映射文件的命名空间;
第二文件生成模块,被配置为执行生成扩展映射文件中的扩展配置文件和扩展接口文件;
其中,扩展映射文件和原始映射文件相同的命名空间用于保证扩展映射文件引用原始映射文件的第一操作语句和第一接口。
在一些可能的实施例中,装置还包括:
操作语句定义模块,被配置为执行在扩展配置文件中定义第二操作语句,得到更新后的扩展配置文件;
接口定义模块,被配置为执行在扩展接口文件中定义第二接口,得到更新后的扩展接口文件;
文件更新模块,被配置为执行基于更新后的扩展配置文件和更新后的扩展接口文件得到更新后的扩展映射文件。
在一些可能的实施例中,第二操作语句对应的操作包括多表联合操作或单表非基础操作。
在一些可能的实施例中,操作语句确定模块,被配置为执行:
利用扩展映射文件中的扩展配置文件引用原始配置文件,确定标识对应的至少一个第一操作语句为目标操作语句。
在一些可能的实施例中,操作语句确定模块,被配置为执行:
基于扩展映射文件生成代理对象;
基于代理对象确定标识对应的目标操作语句。
在一些可能的实施例中,信息获取装置应用于Mybatis数据库持久层框架。
根据本公开实施例的第三方面,提供一种电子设备,包括:处理器;用于存储处理器可执行指令的存储器;其中,处理器被配置为执行指令,以实现如上述第一方面中任一项的方法。
根据本公开实施例的第四方面,提供一种计算机可读存储介质,当计算机可读存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行本公开实施例的第一方面中任一项的方法。
根据本公开实施例的第五方面,提供一种计算机程序产品,计算机程序产品包括计算机程序,计算机程序存储在可读存储介质中,计算机设备的至少一个处理器从可读存储介质读取并执行计算机程序,使得计算机设备执行本公开实施例的第一方面中任一项的方法。
本公开的实施例提供的技术方案至少带来以下有益效果:
获取操作请求,操作请求包括操作语句的标识和执行参数;基于扩展映射文件确定标识对应的目标操作语句,扩展映射文件的命名空间和原始映射文件的命名空间相同;原始映射文件的命名空间基于扩展映射文件的命名空间修改得到,基于目标操作语句获取执行参数的信息。本申请实施例中,扩展映射文件和原始映射文件的相同的命名空间可以用于保证扩展映射文件引用原始映射文件中的配置信息和接口,但是扩展映射文件引用原始映射文件之间是独立的,不会受到原始映射文件更新导致的不良影响。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理,并不构成对本公开的不当限定。
图1是根据一示例性实施例示出的一种应用环境的示意图;
图2是根据一示例性实施例示出的一种信息获取方法的流程图;
图3是根据一示例性实施例示出的一种生成扩展映射文件的方法的流程图;
图4是根据一示例性实施例示出的一种生成扩展映射文件的方法的流程图;
图5是根据一示例性实施例示出的一种信息获取方法的流程图;
图6是根据一示例性实施例示出的一种信息获取装置的框图;
图7是根据一示例性实施例示出的一种用于信息获取的电子设备的框图。
具体实施方式
为了使本领域普通人员更好地理解本公开的技术方案,下面将结合附图,对本公开实施例中的技术方案进行清楚、完整地描述。
需要说明的是,本公开的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的第一对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本公开的实施例能够以除了在这里图示或描述的那些以外的顺序实施。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
本申请中有关用户的所有数据均是用户授权后的数据。
请参阅图1,图1是根据一示例性实施例示出的一种信息获取方法的应用环境的示意图,如图1所示,该应用环境可以包括服务器01和客户端02。其中,数据库可以承载在服务器01上,还可以独立于该服务器01,承载在数据库服务器上。
在一些可能的实施例中,上述的客户端02可以包括但不限于智能手机、台式计算机、平板电脑、笔记本电脑、智能音箱、数字助理、增强现实(augmented reality,AR)/虚拟现实(virtual reality,VR)设备、智能可穿戴设备等类型的客户端。也可以为运行于上述客户端的软体,例如应用程序、小程序等。可选的,客户端上运行的操作系统可以包括但不限于安卓系统、IOS系统、linux、windows、Unix等。
在一些可能的实施例中,客户端02获取操作请求,操作请求包括操作语句的标识和执行参数,基于扩展映射文件确定标识对应的目标操作语句,扩展映射文件的命名空间和原始映射文件的命名空间相同,原始映射文件的命名空间基于扩展映射文件的命名空间修改得到,基于目标操作语句获取执行参数的信息。
可选的,服务器01可以包括是独立的物理服务器,也可以是多个物理服务器构成的服务器集群或者分布式系统,还可以是提供云服务、云数据库、云计算、云函数、云存储、网络服务、云通信、中间件服务、域名服务、安全服务、CDN(Content Delivery Network,内容分发网络)、以及大数据和人工智能平台等基础云计算服务的云服务器。服务器上运行的操作系统可以包括但不限于安卓系统、IOS系统、linux、windows、Unix等。
图2是根据一示例性实施例示出的一种信息获取方法的流程图,如图2所示,信息获取方法可以应用于客户端,也可以应用于其他节点设备,包括以下步骤:
在步骤S201中,获取操作请求;操作请求包括操作语句的标识和执行参数。
本申请实施例中,客户端可以获取操作请求,该操作请求可以是针对某个数据的操作请求,该数据可以位于某个表中。因此,该操作请求可以是针对某个表的内容的查询操作,某个表的内容的增添操作,某个表的内容的删除操作,或者某个表格的更新操作。其中,上述的某个表可以是数据库中的表。该数据库可以存在于客户端中,还可以存在于另外的服务器中。
对应的,当客户端获取到操作请求时,可以对该操作请求进行解析,得到某个操作的操作语句的标识和执行参数。举个例子,假设某个操作是某个表中对于用户“Axxxxxtt”的信息的查询操作,则该操作语句的标识就是查询语句的标识,该执行参数可以是用户名“Axxxxxtt”。
本申请实施例中,上述的信息获取可以是对于数据库中的信息获取。
在步骤S202中,基于扩展映射文件确定标识对应的目标操作语句;扩展映射文件的命名空间和原始映射文件的命名空间相同;原始映射文件的命名空间基于扩展映射文件的命名空间修改得到。
本申请实施例中,信息获取方法可以应用于Mybatis数据库持久层框架。Mybatis是一款优秀的数据库持久层框架,可以免除了几乎所有的java数据库连接(Java DatabaseConnectivity,JDBC)代码以及设置参数和获取结果集的工作。其可以通过简单的可扩展标记语言XML或注解来配置和映射原始类型、接口和简单的Java对象(Plain Ordinary JavaObject,POJO)到数据库中的记录的映射。
利用原生Mybatis-generator生成器基于数据库中的表结构可以生成数据库表对应的原始映射文件Mapper,该原始映射文件包括原始配置文件Mapper.xml和原始接口文件Mapper.java,利用上述原始配置文件Mapper.xml和原始接口文件Mapper.java可以生成了常用的一些数据库表的增删改查操作,但是其操作都是针对单表操作的。
本申请实施例中,原始配置文件Mapper.xml可以包括就要数据库中的表结构生成的第一操作语句,第一数据结构的定义和第一类的定义。原始接口文件Mapper.java可以包括基于数据库中的表结构生成的第一接口。可选的,第一操作语句可以是结构化查询语句SQL语句。
其中,第一类对应的类主要是起到封装数据的作用,对数据进行保护,安全性高。类中包括数据成员和成员函数。且数据成员默认情况下是私有的,即外面访问不到,这样对数据就起到了保护和封闭的作用。而第一数据结构对应的数据结构是开放的,里面的数据默认情况下是公有的,数据结构里面不能有函数。
然而随着对于数据库表中更多操作的需求,基于原始配置文件Mapper.xml和原始接口文件Mapper.java能够提供的简单的对于表的增删改查操作已经不能满足用户的需求,因此需要一种方式来解决原始配置文件Mapper.xml和原始接口文件Mapper.java不能提供更多的针对表的操作的问题。
图3是根据一示例性实施例示出的一种生成扩展映射文件的方法的流程图,如图3所示,包括:
在步骤S301中,基于表结构生成原始映射文件;原始映射文件包括原始配置文件和原始接口文件;原始配置文件包括第一操作语句;原始接口文件包括第一接口。
可选的,上述的表结构可以是数据库的表结构。客户端可以利用原生Mybatis-generator生成器基于数据库中的表结构可以生成数据库表对应的原始映射文件Mapper,其中,原始映射文件Mapper包括原始配置文件Mapper.xml和原始接口文件Mapper.java。
在步骤S302中,生成扩展映射文件。
本申请实施例中,客户端可以继承Mybatis-generator生成器提供的适配器PluginAdapter。并获取扩展映射文件的配置信息。假设原始映射文件的文件名为Mapper,则可以定义扩展映文件的配置信息中的前置信息为Ext,从而确定扩展映射文件的文件名为ExtMapper,再者,可以确定扩展映射文件的配置信息中的存储信息,该存储信息表征该扩展映射文件在设备中的存储区域。当获取扩展映射文件的配置信息后,可以基于该配置信息完成扩展映射文件的生成。
在步骤S303中,将原始映射文件的命名空间修改为扩展映射文件的命名空间。
由于一个大型的工程往往是由若干设备独立完成的,不同的设备分别完成不同的部分,最后再组合成一个完整的程序。由于各个头文件是由不同设备负责,有可能在不同的头文件中用了相同的名字来命名所定义的类或函数,这样在程序中就会出现名字冲突。为了解决命名冲突,C++中引入了命名空间namespace,所谓命名空间就是一个可以由用户自己定义的作用域,在不同的作用域中可以定义相同名字的变量,互不干扰,系统能够区分它们。
命名空间是程序设计者命名的内存区域,程序设计者根据需指定一些有名字的空间域,把一些全局实体分别存放到各个命名空间中,从而与其他全局实体分隔开。通俗的说,每个命名空间都是一个名字空间域,存放在名字空间域中的全局实体只在本空间域内有效。名字空间对全局实体加以域的限制,从而合理的解决命名冲突。
本申请实施例中,为了使得扩展映射文件可以引用原始映射文件的第一操作语句、第一数据结构的定义、第一类的定义和第一接口,即扩展映射文件可以继承原始映射文件,而不用将原始映射文件的第一操作语句、第一数据结构的定义、第一类的定义和第一接口拷贝至扩展映射文件中,可以将原始映射文件的命名空间修改为扩展映射文件的命名空间。
在步骤S304中,生成扩展映射文件中的扩展配置文件和扩展接口文件;其中,扩展映射文件和原始映射文件相同的命名空间用于保证扩展映射文件引用原始映射文件的第一操作语句和第一接口。
然后,客户端可以在扩展映射文件生成扩展配置文件ExtMapper.xml和扩展接口文件ExtMapper.java。
由于上文已经说到,客户端是利用原生Mybatis-generator生成器基于数据库中的表结构可以生成数据库表对应的原始配置文件Mapper.xml和原始接口文件Mapper.java。因此,当数据库中的表结构发生变化时,客户端将再次使用原生Mybatis-generator生成器基于变化后的数据库中的表结构可以生成数据库表对应的新的原始配置文件Mapper.xml和新的原始接口文件Mapper.java。当原始映射文件的命名空间修改为扩展映射文件的命名空间后,扩展映射文件可以直接应用新的原始映射文件,即扩展配置文件可以引用新的原始配置文件中的第一操作语句、第一数据结构的定义和第一类的定义,扩展接口文件可以应用新的原始接口文件。因此,无论原始配置文件Mapper.xml和原始接口文件Mapper.java怎么进行更新,都不会影响到扩展配置文件ExtMapper.xml和扩展接口文件ExtMapper.java定义的新的内容。
若本申请实施例中,扩展映射文件仅仅只是和原始映射文件的命名空间保持一致,使得扩展映射文件可以直接引用原始映射文件中的第一操作语句或者定义的第一数据结构,以及使用第一接口,那么其能实现的还是简单的常用的针对数据库单表的增删改查操作,不能满足用户的多样性需求。基于此,图4是根据一示例性实施例示出的一种生成扩展映射文件的方法的流程图,如图4所示,包括:
在步骤S401中,在扩展配置文件中定义第二操作语句,得到更新后的扩展配置文件。
本申请实施例中,第二操作语句对应的操作包括多表联合操作或单表非基础操作。可选的,第二操作语句可以是结构化查询语句SQL语句。
其中,多表联合操作可以是多表联合查询操作、多表联合查询操作,多表联合增添操作、多表联合删除操作和多表联合更新操作。
其中,单表非基础操作可以包括自定义的针对某个事情的操作,比如扉页的查询操作。
在步骤S402中,在扩展接口文件中定义第二接口,得到更新后的扩展接口文件。
本申请实施例中,定义的第二接口可以是实施上述第二操作语句对应的操作所要用到的接口。
在步骤S403中,基于更新后的扩展配置文件和更新后的扩展接口文件得到更新后的扩展映射文件。
本申请实施例中,客户端可以接收操作语句定义指令,并根据操作语句定义指令在扩展配置文件中定义第二操作语句,得到更新后的扩展配置文件。可选的,除了在扩展配置文件中定义第二操作语句,还可以定义第二数据结构和第二类。
本申请实施例中,客户端可以接收接口定义指令,该接口定义指令中定义的接口可以上述新定义的第二操作语句对应的接口。随后,根据接口定义指令在扩展接口文件中定义第二接口,得到更新后的扩展接口文件。
基于上述的阐述,一种可选的客户端基于扩展映射文件确定标识对应的目标操作语句的实施例中,客户端可以利用扩展映射文件中的扩展配置文件引用原始配置文件,确定标识对应的至少一个第一操作语句为目标操作语句。
如此,客户端可以基于更新后的扩展配置文件和更新后的扩展接口文件得到更新后的扩展映射文件。既可以通过更新后的扩展映射文件引用原始映射文件中原始配置文件和原始接口文件完成基础的操作,还可以通过更新后的扩展映射文件中自定义的第二操作数据和第二接口完成更多的、复杂的、自定义的针对数据库中表的操作。
在一种可选的实施例中,假设客户端加载有Mybatis数据库持久层框架,且基于原始映射文件生成了扩展映射文件,即扩展映射文件继承于原始映射文件。其中,两个文件的命名空间相同。则当客户端发起数据查询时,可以基于用户的操作生成一个获取操作请求,操作请求包括操作语句的标识和执行参数。随后将该获取操作请求转发到具体的服务service层,该服务器位于客户端中。随后,服务层基于扩展映射文件确定标识对应的目标操作语句和该目标操作数据对应的mapper接口,随后,服务层可以调用该mapper接口基于目标操作数据获取执行参数的信息。具体的,客户端可以向内置于客户端的数据库或者向数据库所在的服务器发送操作指令,操作指令包括执行参数和目标操作语句;操作指令用于指示数据库基于执行参数和目标操作语句确定执行反馈,即得到执行参数的信息。
在一种可选的实施例中,除了数据库服务器之外,可以包括前端设备和后端服务器。其中,后端服务器承载有Mybatis数据库持久层框架,可以基于原始映射文件生成扩展映射文件,且两个文件的命名空间相同。前端设备发起数据查询的时候,可以基于用户的操作生成一个操作请求,操作请求包括操作语句的标识和执行参数。随后将该获取操作请求转发到后端服务器,后端服务器会将操作指令转发至具体的服务service层。随后,服务层基于扩展映射文件确定标识对应的目标操作语句和该目标操作数据对应的mapper接口。服务层可以调用该mapper接口向数据库所在的服务器发送操作指令,操作指令包括执行参数和目标操作语句;操作指令用于指示数据库基于执行参数和目标操作语句确定执行反馈,该执行反馈可以是执行参数的信息。
在一些可能的实施例中,数据库和客户端之间的交互通过代理对象实现是一种可行的模式,其目的就是为真实对象(扩展映射文件)提供一个代理对象以控制对真实对象的访问。代理对象负责为被代理对象,及真实对象预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理。为了保持行为的一致性,代理对象和真实对象通常会实现相同的接口,所以在访问者看来两者没有丝毫的区别。通过代理对象这中间一层,能有效控制对真实对象的直接访问,也可以很好地隐藏和保护真实对象,同时也为实施不同控制策略预留了空间,从而在设计上获得了更大的灵活性。
基于此,图5是根据一示例性实施例示出的一种信息获取方法的流程图,如图5所示,包括:
在步骤S2021中,基于扩展映射文件生成代理对象。
本申请实施例中,客户端可以根据扩展映射文件中的扩展配置文件和扩展接口文件生成代理类,这里的代理类可以被称为代理对象。
在步骤S2022中,基于代理对象确定标识对应的目标操作语句。
本申请实施例中,客户端可以基于代理类确定标识对应的目标操作语句。
在步骤S203中,基于目标操作语句获取执行参数的信息。
本申请实施例中,当客户端确定好目标操作语句后,可以向数据库所在的客户端发送操作指令,该操作指令包括执行参数和目标操作语句。操作指令用于指示数据库基于执行参数和目标操作语句确定执行反馈。
当数据库确定执行反馈后,可以将执行反馈通过客户端发送至客户端,比如当数据库基于执行参数和目标操作语句查询“Axxxxxtt”的信息后,可以将“Axxxxxtt”的信息作为执行反馈通过服务发送给客户端。
综上,本申请实施例中,本申请实施例既可以通过的扩展映射文件引用原始映射文件中原始配置文件和原始接口文件完成基础的表操作,还可以通过扩展映射文件中自定义的第二操作数据和第二接口完成更多的、复杂的、用户自定义的针对数据库中表的操作。
且,当数据库中的表结构发生变化时,客户端将使用原生Mybatis-generator生成器基于变化后的数据库中的表结构可以生成数据库表对应的新的原始配置文件Mapper.xml和新的原始接口文件Mapper.java。当原始映射文件的命名空间修改为扩展映射文件的命名空间后,扩展映射文件可以直接应用新的原始映射文件,即扩展配置文件可以引用新的原始配置文件中的第一操作语句,扩展接口文件可以应用新的原始接口文件。因此,无论原始配置文件Mapper.xml和原始接口文件Mapper.java怎么进行更新,都不会影响到扩展配置文件ExtMapper.xml和扩展接口文件ExtMapper.java定义的新的第二操作数据和第二接口。
图6是根据一示例性实施例示出的一种信息获取装置框图。参照图6,该装置包括获取模块601、操作语句确定模块602和指令发送模块603。
获取模块601,被配置为执行获取操作请求;操作请求包括操作语句的标识和执行参数;
操作语句确定模块602,被配置为执行基于扩展映射文件确定标识对应的目标操作语句;扩展映射文件的命名空间和原始映射文件的命名空间相同;原始映射文件的命名空间基于扩展映射文件的命名空间修改得到;
信息获取模块603,被配置为执行基于目标操作语句获取执行参数的信息。
在一些可能的实施例中,装置还包括:
第一文件生成模块,被配置为执行基于表结构生成原始映射文件;原始映射文件包括原始配置文件和原始接口文件;原始配置文件包括第一操作语句;原始接口文件包括第一接口;
第二文件生成模块,被配置为执行生成扩展映射文件;
修改模块,被配置为执行将原始映射文件的命名空间修改为扩展映射文件的命名空间;
第二文件生成模块,被配置为执行生成扩展映射文件中的扩展配置文件和扩展接口文件;
其中,扩展映射文件和原始映射文件相同的命名空间用于保证扩展映射文件引用原始映射文件的第一操作语句和第一接口。
在一些可能的实施例中,装置还包括:
操作语句定义模块,被配置为执行在扩展配置文件中定义第二操作语句,得到更新后的扩展配置文件;
接口定义模块,被配置为执行在扩展接口文件中定义第二接口,得到更新后的扩展接口文件;
文件更新模块,被配置为执行基于更新后的扩展配置文件和更新后的扩展接口文件得到更新后的扩展映射文件。
在一些可能的实施例中,第二操作语句对应的操作包括多表联合操作或单表非基础操作。
在一些可能的实施例中,操作语句确定模块,被配置为执行:
利用扩展映射文件中的扩展配置文件引用原始配置文件,确定标识对应的至少一个第一操作语句为目标操作语句。
在一些可能的实施例中,操作语句确定模块,被配置为执行:
基于扩展映射文件生成代理对象;
基于代理对象确定标识对应的目标操作语句。
在一些可能的实施例中,信息获取装置应用于Mybatis数据库持久层框架。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图7是根据一示例性实施例示出的一种用于信息获取的装置700的框图。例如,装置700可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图7,装置700可以包括以下一个或多个组件:处理组件702,存储器704,电力组件706,多媒体组件708,音频组件710,输入/输出(I/O)的接口712,传感器组件714,以及通信组件716。
处理组件702通常控制装置700的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件702可以包括一个或多个处理器720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件702可以包括一个或多个模块,便于处理组件702和其他组件之间的交互。例如,处理组件702可以包括多媒体模块,以方便多媒体组件708和处理组件702之间的交互。
存储器704被配置为存储各种类型的数据以支持在设备700的操作。这些数据的示例包括用于在装置700上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件706为装置700的各种组件提供电力。电源组件706可以包括电源管理系统,一个或多个电源,及其他与为装置700生成、管理和分配电力相关联的组件。
多媒体组件708包括在所述装置700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件708包括一个前置摄像头和/或后置摄像头。当设备700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件710被配置为输出和/或输入音频信号。例如,音频组件710包括一个麦克风(MIC),当装置700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器704或经由通信组件716发送。在一些实施例中,音频组件710还包括一个扬声器,用于输出音频信号。
I/O接口712为处理组件702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件714包括一个或多个传感器,用于为装置700提供各个方面的状态评估。例如,传感器组件714可以检测到设备700的打开/关闭状态,组件的相对定位,例如所述组件为装置700的显示器和小键盘,传感器组件714还可以检测装置700或装置700一个组件的位置改变,用户与装置700接触的存在或不存在,装置700方位或加速/减速和装置700的温度变化。传感器组件714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件714还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件714还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件716被配置为便于装置700和其他设备之间有线或无线方式的通信。装置700可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件716经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件716还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置700可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的存储介质,例如包括指令的存储器704,上述指令可由装置700的处理器720执行以完成上述方法。可选地,存储介质可以是非临时性计算机可读存储介质,例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
Claims (10)
1.一种信息获取方法,其特征在于,包括:
获取操作请求;所述操作请求包括操作语句的标识和执行参数;
基于扩展映射文件确定所述标识对应的目标操作语句;所述扩展映射文件的命名空间和原始映射文件的命名空间相同;所述原始映射文件的命名空间基于所述扩展映射文件的命名空间修改得到;
基于所述目标操作语句获取所述执行参数的信息。
2.根据权利要求1所述的信息获取方法,其特征在于,所述基于扩展映射文件确定所述标识对应的目标操作语句之前,还包括:
基于表结构生成所述原始映射文件;所述原始映射文件包括原始配置文件和原始接口文件;所述原始配置文件包括第一操作语句;所述原始接口文件包括第一接口;
生成所述扩展映射文件;
将所述原始映射文件的命名空间修改为所述扩展映射文件的命名空间;
生成所述扩展映射文件中的扩展配置文件和扩展接口文件;
其中,所述扩展映射文件和所述原始映射文件相同的命名空间用于保证所述扩展映射文件引用所述原始映射文件的所述第一操作语句和所述第一接口。
3.根据权利要求2所述的信息获取方法,其特征在于,所述方法还包括:
在所述扩展配置文件中定义第二操作语句,得到更新后的扩展配置文件;
在所述扩展接口文件中定义第二接口,得到更新后的扩展接口文件;
基于所述更新后的扩展配置文件和所述更新后的扩展接口文件得到更新后的扩展映射文件。
4.根据权利要求3所述的信息获取方法,其特征在于,所述第二操作语句对应的操作包括多表联合操作或单表非基础操作。
5.根据权利要求3所述的信息获取方法,其特征在于,所述基于扩展映射文件确定所述标识对应的目标操作语句包括:
利用所述扩展映射文件中的所述扩展配置文件引用所述原始配置文件,确定所述标识对应的至少一个第一操作语句为所述目标操作语句。
6.根据权利要求1所述的信息获取方法,其特征在于,所述基于扩展映射文件确定所述标识对应的目标操作语句包括:
基于所述扩展映射文件生成代理对象;
基于所述代理对象确定所述标识对应的目标操作语句。
7.一种信息获取装置,其特征在于,包括:
获取模块,被配置为执行获取操作请求;所述操作请求包括操作语句的标识和执行参数;
操作语句确定模块,被配置为执行基于扩展映射文件确定所述标识对应的目标操作语句;所述扩展映射文件的命名空间和原始映射文件的命名空间相同;所述原始映射文件的命名空间基于所述扩展映射文件的命名空间修改得到;
信息获取模块,被配置为执行基于所述目标操作语句获取所述执行参数的信息。
8.一种电子设备,其特征在于,包括:
处理器;
用于存储所述处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令,以实现如权利要求1至6中任一项所述的信息获取方法。
9.一种计算机可读存储介质,其特征在于,当所述计算机可读存储介质中的指令由电子设备的处理器执行时,使得所述电子设备能够执行如权利要求1至6中任一项所述的信息获取方法。
10.一种计算机程序产品,其特征在于,所述计算机程序产品包括计算机程序,所述计算机程序存储在可读存储介质中,计算机设备的至少一个处理器从所述可读存储介质读取并执行所述计算机程序,使得所述计算机设备执行如权利要求1至6中任一项所述的信息获取方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111350121.5A CN114201504A (zh) | 2021-11-15 | 2021-11-15 | 一种信息获取方法、装置、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111350121.5A CN114201504A (zh) | 2021-11-15 | 2021-11-15 | 一种信息获取方法、装置、电子设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114201504A true CN114201504A (zh) | 2022-03-18 |
Family
ID=80647610
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111350121.5A Pending CN114201504A (zh) | 2021-11-15 | 2021-11-15 | 一种信息获取方法、装置、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114201504A (zh) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1871598A (zh) * | 2003-08-21 | 2006-11-29 | 微软公司 | 用于可由硬件/软件接口系统管理的信息单元的扩展和继承的系统和方法 |
CN105824619A (zh) * | 2016-03-10 | 2016-08-03 | 四川交通职业技术学院 | 基于Spring MVC、Apache Shiro、MyBatis框架整合的代码生成器 |
US20160358130A1 (en) * | 2015-06-04 | 2016-12-08 | Easy Payment Gateway, Ltd. | Method and Apparatus for Providing an Electronic Transaction Gateway |
CN109144966A (zh) * | 2018-07-06 | 2019-01-04 | 航天星图科技(北京)有限公司 | 一种海量时空数据的高效组织与管理方法 |
CN110046170A (zh) * | 2019-04-22 | 2019-07-23 | 深圳乐信软件技术有限公司 | 基于多文件管理的语句执行方法、装置、设备和介质 |
CN113468232A (zh) * | 2017-02-27 | 2021-10-01 | 分秒库公司 | 用于查询时间序列数据的可扩展数据库系统 |
-
2021
- 2021-11-15 CN CN202111350121.5A patent/CN114201504A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1871598A (zh) * | 2003-08-21 | 2006-11-29 | 微软公司 | 用于可由硬件/软件接口系统管理的信息单元的扩展和继承的系统和方法 |
US20160358130A1 (en) * | 2015-06-04 | 2016-12-08 | Easy Payment Gateway, Ltd. | Method and Apparatus for Providing an Electronic Transaction Gateway |
CN105824619A (zh) * | 2016-03-10 | 2016-08-03 | 四川交通职业技术学院 | 基于Spring MVC、Apache Shiro、MyBatis框架整合的代码生成器 |
CN113468232A (zh) * | 2017-02-27 | 2021-10-01 | 分秒库公司 | 用于查询时间序列数据的可扩展数据库系统 |
CN109144966A (zh) * | 2018-07-06 | 2019-01-04 | 航天星图科技(北京)有限公司 | 一种海量时空数据的高效组织与管理方法 |
CN110046170A (zh) * | 2019-04-22 | 2019-07-23 | 深圳乐信软件技术有限公司 | 基于多文件管理的语句执行方法、装置、设备和介质 |
Non-Patent Citations (1)
Title |
---|
顾梦园等: "保障性住房资格管理系统设计与实现", 《计算机科学与应用》, vol. 9, no. 3, 21 March 2019 (2019-03-21), pages 650 - 662 * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109388625B (zh) | 多分布式文件系统中处理配置文件的方法及装置 | |
US10909203B2 (en) | Method and device for improving page display effect via execution, conversion and native layers | |
CN109033393B (zh) | 贴纸处理方法、装置、存储介质及电子设备 | |
CN115185717B (zh) | 接口调用方法、装置、电子设备和存储介质 | |
CN111752598A (zh) | 页面生成方法、装置、电子设备及存储介质 | |
US20160006787A1 (en) | Methods and devices for visiting a webpage | |
CN106708967B (zh) | 页面显示方法及装置 | |
CN105468606B (zh) | 网页保存的方法及装置 | |
CN112328330A (zh) | iOS组件的调用方法、装置、中间件、电子设备及介质 | |
CN113111123A (zh) | 集群业务的调用方法、装置、电子设备、存储介质及产品 | |
CN110989987B (zh) | 一种门户网页的生成方法、装置、客户端、服务器及存储介质 | |
CN109522286B (zh) | 文件系统的处理方法和装置 | |
CN111382161A (zh) | 状态数据处理方法、装置、电子设备及存储介质 | |
CN110928854A (zh) | 数据导入方法、装置及电子设备 | |
CN114201504A (zh) | 一种信息获取方法、装置、电子设备及存储介质 | |
CN112860625B (zh) | 数据获取方法、数据存储方法、装置、设备及存储介质 | |
CN113448642B (zh) | 系统文件访问方法、装置和电子设备 | |
CN110995767B (zh) | 一种请求处理方法及装置 | |
CN109032583B (zh) | 数据交互方法及装置 | |
CN112988822A (zh) | 数据查询方法、装置、设备、可读存储介质以及产品 | |
CN107257384B (zh) | 服务状态监控方法及装置 | |
CN108509641B (zh) | 文件备份的方法、装置、服务器以及系统 | |
CN113378022A (zh) | 一种站内搜索平台、搜索方法和相关装置 | |
CN112800285B (zh) | 基于图数据库的数据查询方法、设备、存储介质及产品 | |
CN112231727B (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 |