CN112883082B - 一种查询动态列的实现方法、装置及设备 - Google Patents
一种查询动态列的实现方法、装置及设备 Download PDFInfo
- Publication number
- CN112883082B CN112883082B CN202110206502.XA CN202110206502A CN112883082B CN 112883082 B CN112883082 B CN 112883082B CN 202110206502 A CN202110206502 A CN 202110206502A CN 112883082 B CN112883082 B CN 112883082B
- Authority
- CN
- China
- Prior art keywords
- query
- information
- client
- data
- counted
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 41
- 238000012545 processing Methods 0.000 claims abstract description 106
- 238000009877 rendering Methods 0.000 claims abstract description 50
- 230000008569 process Effects 0.000 claims description 14
- 230000002776 aggregation Effects 0.000 claims description 8
- 238000004220 aggregation Methods 0.000 claims description 8
- 238000004458 analytical method Methods 0.000 claims description 5
- 238000010586 diagram Methods 0.000 description 16
- 238000004364 calculation method Methods 0.000 description 3
- 238000007405 data analysis Methods 0.000 description 3
- 238000011161 development Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 238000007619 statistical method Methods 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 230000004075 alteration Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 238000012163 sequencing technique Methods 0.000 description 1
- 238000004148 unit process Methods 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
- G06F16/245—Query processing
- G06F16/2458—Special types of queries, e.g. statistical queries, fuzzy queries or distributed queries
- G06F16/2462—Approximate or statistical queries
-
- 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
- G06F16/245—Query processing
- G06F16/2455—Query execution
- G06F16/24552—Database cache management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
- G06F40/174—Form filling; Merging
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
- G06F40/177—Editing, e.g. inserting or deleting of tables; using ruled lines
- G06F40/18—Editing, e.g. inserting or deleting of tables; using ruled lines of spreadsheets
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Computational Linguistics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- Probability & Statistics with Applications (AREA)
- Data Mining & Analysis (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- General Health & Medical Sciences (AREA)
- Fuzzy Systems (AREA)
- Mathematical Physics (AREA)
- Software Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本说明书实施例公开了一种查询动态列的方法、装置及设备,用以提供一种灵活度和扩展性高的查询方式。包括:接收客户端发送的查询请求;其中,查询请求包括查询参数;解析查询参数,确定出需要统计的数据信息;对需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将动态列信息和统计数据发送至所述客户端;基于客户端调用渲染服务,确定出查询格式;将查询格式发送至客户端,以便客户端通过加载查询格式进行页面渲染,完成统计数据的加载。
Description
技术领域
本说明书涉及数据分析处理领域,尤其涉及一种查询动态列的实现方法、装置及设备。
背景技术
现在属于数据信息的时代,无论是个人还是企业每天都会产生大量的数据。电商、团购、外卖、新媒体都可以通过用户的行为习惯,为客户进行精准推送。企业同时也可以通过数据进行决策与规划。
对于数据的分析计算以及数据的展示要求越来越高,需求也越来越复杂,以往的查询报表只能针对单一需求,以固定的统计维度进行数据分析和展现。当需要从多维度、多角度进行数据的分析展示时,查询报表中默认的格式信息、查询参数等会根据分析统计的维度或角度而发生变化,需要创建不同的查询方式来实现。
基于此,需要一种灵活度和扩展性高的查询方式来支持动态列。
发明内容
本说明书一个或多个实施例提供了一种查询动态列的实现方法、装置及设备,用于解决如下技术问题:需要一种灵活度和扩展性高的查询方式来支持动态列。
本说明书一个或多个实施例采用下述技术方案:
本说明书一个或多个实施例提供一种查询动态列的实现方法,应用于服务器端,该方法包括:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
可选地,所述解析所述查询参数,确定出需要统计的数据信息,具体包括:
确定预先建立的查询对象,并对应所述查询对象新增处理单元;
在所述处理单元中,解析所述查询参数;
根据所述查询参数的排列组合,确定出需要统计的数据信息。
可选地,所述处理单元包括分页处理单元、汇总合计处理单元、排序处理单元、分组合计处理单元、数据格式化处理单元以及内置取数逻辑处理单元中的一项或多项。
可选地,所述对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,具体包括:
对所述需要统计的数据信息进行工处理;
将所述处理单元添加到执行队列中,以便内置的查询框架在执行查询流程时,自动处理执行队列中的处理单元,确定出动态列信息和统计数据。
可选地,所述基于所述客户端调用渲染服务,确定出查询格式,具体包括:
基于所述客户端通过所述动态列信息调用所述渲染服务;
确定所述渲染服务默认的查询格式信息;
将所述默认的查询格式信息与所述动态列信息进行merge操作,确定出所述查询格式。
可选地,所述将所述默认查询格式信息与所述动态列信息进行merge操作,确定出所述查询格式,具体包括:
将所述默认格式信息显示的列信息与所述动态列信息进行合并,得到需要统计和展示的数据列;
根据所述需要统计和展示的数据列得到对应的列信息;其中,所述列信息包括绑定字段、列的宽度、字体、字号中的一项或多项;
根据所述列信息确定出所述查询格式。
本说明书的一个或多个实施例提供了一种查询动态列的实现方法,应用于客户端,该方法包括:
向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
根据所述动态列信息调用渲染服务,获得查询格式;
根据所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书的一个或多个实施例提供了一种查询动态列的实现装置,应用于服务器端,所述装置包括:
接收单元,用于接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析单元,用于解析所述查询参数,确定出需要统计的数据信息;
处理单元,用于对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
渲染单元,用于基于所述客户端调用渲染服务,确定出查询格式;
结果单元,用于将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书的一个或多个实施例提供了一种查询动态列的实现装置,应用于客户端,所述装置包括:
发送单元,用于向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收单元,用于接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
渲染单元,用于根据所述动态列信息为参数调用渲染服务,获得查询格式;
结果单元,用于根据所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书的一个或多个实施例提供了一种查询动态列的实现设备,应用于服务器端,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书的一个或多个实施例提供了一种查询动态列的实现设备,应用于客户端,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
根据所述动态列信息调用渲染服务,获得查询格式;
根据所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书一个或多个实施例提供的一种非易失性计算机存储介质应用于服务器端,存储有计算机可执行指令,所述计算机可执行指令设置为:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书一个或多个实施例提供的一种非易失性计算机存储介质应用于客户端,存储有计算机可执行指令,所述计算机可执行指令设置为:
向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
根据所述动态列信息调用渲染服务,获得查询格式;
根据所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书实施例采用的上述至少一个技术方案能够达到以下有益效果:
通过在查询对象中新增处理单元,对查询条件变化后的参数进行解析处理,以代码的方式动态组织需要统计的数据列信息,可以实现对查询报表进行多维度、多角度数据查询时的灵活度,也扩展了查询框架中处理单元执行队列的功能。在服务器端进行渲染服务生成查询格式的模板后,即生成缓存片段,当有相似的查询参数进行报表生成时,可以直接使用对应的查询格式,减少了在数据库中查询浪费的时间。
附图说明
为了更清楚地说明本说明书实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本说明书中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。在附图中:
图1为本说明书实施例提供的一种查询动态列的查询架构的示意图;
图2为本说明书实施例提供的一种应用于服务器端的查询动态列的实现方法的流程图;
图3为本说明书实施例提供的一种查询动态列中查询对象以及处理单元的设置示意图;
图4为本说明书实施例提供的一种应用于客户端的查询动态列的实现方法的流程图;
图5为本说明书实施例提供的一种应用于服务器端的查询动态列的实现装置的结构示意图;
图6为本说明书实施例提供的一种应用于服务器端的查询动态列的实现设备的结构示意图;
图7为本说明书实施例提供的一种应用于服务器端的查询动态列的实现介质的结构示意图;
图8为本说明书实施例提供的一种应用于客户端的查询动态列的实现装置的结构示意图;
图9为本说明书实施例提供的一种应用于客户端的查询动态列的实现设备的结构示意图;
图10为本说明书实施例提供的一种应用于客户端的查询动态列的实现介质的结构示意图。
具体实施方式
本说明书实施例提供一种查询动态列的实现方法、装置及设备。
为了使本技术领域的人员更好地理解本说明书中的技术方案,下面将结合本说明书实施例中的附图,对本说明书实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本说明书保护的范围。
随着数据信息的高速发展,在工作生活中对数据的分析计算以及数据的展示要求越来越高。传统的查询报表只能针对单一需求,以固定的统计维度进行数据的分析和展现。然而,在一些特殊场景下,检索的字段或查询的条件在程序运行期间是动态变化的,在处理不同检索字段或查询条件的查询结果集时,统计的数据会根据查询条件的不同相应的增加几行或几列。例如,科目余额表在默认情况下只统计某账簿、某科目下的初期金额、本期发生金额、余额,当查询条件发生变化后除了统计初期金额、本期发生金额、余额外,还要增加一列累计发生金额。因此,固定单一的查询报表无法从多维度、多角度对不同的数据进行分析展示。
为了解决单一查询报表无法对不同数据进行多维度、多角度的统计分析等问题。本说明书提供了一种查询动态列的实现方法、装置及设备。
以下结合附图,详细说明本说明书提供的技术方案。
如图1所示,图1为本说明书一个或多个实施例提供的一种查询动态列的查询架构的示意图。该查询框架包含了服务器端和客户端的在查询框架中进行查询的流程,以及服务器端与客户端之间的交互工作。为了清楚的表达查询动态列的实现方法,下面首先从服务器端对查询动态列的实现方法做出说明。
图2为本说明书实施例提供的一种应用于服务器端的查询动态列的实现方法的流程图。
图2中的流程可以包括以下步骤:
S201:接收客户端发送的查询请求;其中,所述查询请求包括查询参数。
本说明书的一个或多个实施例中,客户端可以为电商、团购、外卖、新媒体等需要进行数据查询展示个人或企业的查询设备。
本说明书的一个或多个实施例中可以使用IGIX查询平台作为数据查询分析的平台,并以业务查询语言(Business Query Language,BQL)为基础进行数据查询。
需要说明的是,IGIX是基于云原生和微服务架构,包含技术、数据、业务的数字化能力平台,提供可视化、组件化的查询开发制作、发布工具,可以支撑企业技术、业务、数据与商业融合创新。业务查询语言,是在以往统计分析应用中提炼出的,可以利用其可视化界面对业务语言进行查询、分组汇总、过滤、排序等操作实现对数据库数据自由查询的需求,并且通过BQL引擎可以转换为数据库可执行的结构化查询语言。
S202:解析所述查询参数,确定出需要统计的数据信息。
在本说明的一个或多个实施例中,解析查询参数,确定出需要统计的数据信息,具体包括:
确定预先建立的查询对象,并对应所述查询对象新增处理单元;
在所述处理单元中,解析所述查询参数;
根据所述查询参数的排列组合,确定出需要统计的数据信息。
在本说明书的一个或多个实施例中,所述处理单元包括:分页处理单元、汇总合计处理单元、排序处理单元、分组合计处理单元、数据格式化处理单元以及内置取数逻辑处理单元中的一项或多项。
在进行报表查询的过程中,查询对象是数据加工的最小单元,是查询数据组织的核心载体,封装了数据处理的核心逻辑,查询对象的内部由处理单元的执行队列组成,而处理单元是进行数据处理的最小单元。
本说明书的一个或多个实施例中,查询框架基于过往的查询业务需求内置了分页处理单元、汇总合计处理单元、排序处理单元、分组合计处理单元、数据格式化处理单元以及取数逻辑处理单元等多个处理单元。对数据进行处理和统计时,处理单元可以采用串行或者并行的方式在执行队列中进行,以自适应调节处理的过程,节省处理的时间,提高了报表查询的灵活度。
如果在预先建立的查询对象中,查询条件发生变化,使得过往的业务需求无法满足当前查询业务时。开发人员可以在相应的查询对象中新增处理单元,该新增处理单元可以是一个经过开发人员二次开发过的自定义处理单元,使得开发人员可以对新增处理单元进行自定义的功能设定,以对应相应的查询参数。在对处理单元进行二次开发的过程中,保留了开发人员的机动灵活性,使得查询框架可以不断根据业务需求进行同步更新。
通过新增处理单元的解析,获得查询请求中包含的查询参数后,根据参数的排列组合可以确定出需要统计的数据信息。当查询参数为A、B、C时,需要对数据1、数据2、数据3、数据4进行统计计算;而当查询的过滤条件发生变化后,查询参数变为A、B、C、D而此时需要统计的数据就变为了数据1、数据2、数据3、数据4、数据5、数据6。例如,当需要查询2020年度产品的销售数据量、销售金额以及销售增长率时,需要向数据库中调用的数据为2020年的销售数据量、2020年的销售金额和2019年的销售数量。而当需要查询2020年度产品的销售数量、销售金额、销售增长率和毛利时,就需要向数据库中调用2020年的销售数据量、2020年的销售金额和2019年的销售数量、产品的进价额以及包装购买额等。此时,需要统计的数据就根据查询参数的变化相应的发生了变化。需要说明的是,在进行数据统计的过程中,所需要统计的数据可能存储于图3中不同的数据库DataBase中,在进行数据统计的调用时可以跨数据库进行多数据库的查询统计工作。
通过在查询对象中新增处理单元,对查询条件变化后的参数进行解析处理,以代码的方式动态组织需要统计的数据列信息,可以实现对查询报表进行多维度、多角度数据查询时的灵活度,也扩展了查询框架中处理单元执行队列的功能。
S203:对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端。
本说明书的一个或多个实施例中,对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,具体包括:
对所述需要统计的数据信息进行加工处理;
将所述处理单元添加到执行队列中,以便内置的查询框架在执行查询流程时,自动处理执行队列中的处理单元,确定出动态列信息和统计数据。
需要说明的是,在处理和解析出客户端查询请求中包含的查询参数后,可以通过代码的方式确定出需要统计的数据信息,并通过处理单元对所述需要统计的数据进行加工处理。如图3所示为本申请中一个或多个实施例中查询对象以及单元处理的分布。由图3可以看出,经过内置取数获得参数数据后,需要统计的数据需要经过多个处理单元的加工处理。
例如,当包含年龄、身高性别等参数,并需要对不同年龄段不同性别的身高进行查询时,就需要处理单元进行排序分组的处理;当需要查询平均年龄时就需要经过处理单元进行聚合计算;当需要查询平均年龄超过30岁的性别及姓名时,需要进行分组和聚合的结合处理;当需要对上面三种情况进行查询个数以及每页报表中显示数据的个数进行限制时,则需要进行分页处理。
将处理单元添加到执行队列中,使得查询框架在执行查询流程时可以自动执行队列中的处理单元,从而确定出动态列信息和统计数据,并将动态列信息和统计数据返回客户端,以供客户端进行渲染服务。
S204:基于所述客户端调用渲染服务,确定出查询格式。
在本说明书的一个或多个实施例中,基于所述客户端调用渲染服务,确定出查询格式,具体包括:
基于所述客户端通过所述动态列信息调用所述渲染服务;
确定所述渲染服务默认的查询格式;
将所述默认的查询格式信息与所述动态列信息进行merge操作,确定出所述查询格式。
本说明书的一个或多个实施例中,将所述默认查询格式信息与所述动态列信息进行merge操作,确定出所述查询格式,具体包括:
将所述默认格式信息显示的列信息与所述动态列信息进行合并,得到需要统计和展示的数据列;
根据所述需要统计和展示的数据列得到对应的列信息;其中,所述列信息包括绑定字段、列的宽度、字体、字号中的一项或多项;
根据所述列信息确定出所述查询格式。
本说明书的一个或多个实施例中,利用默认格式信息渲染初始页面的格式信息,获得默认格式信息下需要进行渲染的列信息。将默认格式信息和通过代码动态组织的动态列信息进行merge操作,获得最终需要统计和展示的数据列。假设当查询参数为a、b、c时,默认格式信息下的列信息如下表1所示,包含列1,列2,列3的列信息。当查询的过滤条件发生变化后,查询参数做适应性改变对应的也需要多统计列信息,而此时就需要通过代码动态组织列A和列B。例如下表2所示,动态列信息为列A和列B,那么通过merge操作后,获得合并后的需要统计和展示的数据列如下表3所示。需要说明的是,列信息中包含了绑定字段,列的宽度,字体,字号等多种信息。其中,绑定字段是最简单的字段类型,它将数据简单的显示为文本包含了每个列中需要显示的数据。
列1 | 列2 | 列3 |
表1
列A | 列B |
表2
列1 | 列A | 列B | 列2 | 列3 |
表3
S205:将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
如图3所示,需要说明的是,服务器不仅将所述查询格式发送到了客户端,也将查询格式进行了缓存,当有相似的查询参数时可以直接服务器中调用查询格式以供客户端进行渲染。
上述说明从服务器端对查询动态列的实现方式做了说明,为了更加清楚的对查询流程进行说明,下面将从客户端来对查询动态列的实现方法进行说明。
图4为本说明书一个或多个实施例提供的一种应用于客户端的查询动态列的实现方法的流程图。
图4中的流程可以包括以下步骤:
S401:向服务器端发送查询请求;其中,所述查询请求包括查询参数。
S402:接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的架构处理得到的。
其中,动态列信息和统计数据的生成过程,参照上述步骤S203中的过程。
S403:根据所述动态列信息为参数调用渲染服务,获得查询格式。
客户端在接收动态列信息和统计数据后,将接收到的动态列信息作为参数向服务器端调用渲染服务,服务器端将默认的查询格式信息也就是报表的初始页面信息与动态列信息进行合并(merge)操作,将生成的完整的查询格式返回客户端。
需要说明的是,服务器端进行渲染服务时因为服务器端完成了查询格式的模板生成,只需要直接渲染出来。所以客户端的耗时较少,无需占用客户端资源。即生成查询格式的工作完全交由后端服务器来做,客户端只要解析查询格式即可。这样对于客户端的资源占用更少,也可以节省电力资源。服务器端在生成查询格式的模板后,即生成缓存片段,可以减少数据库查询浪费的时间,对于数据变化不大的查询报表可以直接调用服务器端缓存的查询格式,使得查询流程变得更加便捷快速。
S404:根据所述查询格式进行页面渲染,完成所述统计数据的加载。
客户端在接收到查询格式后,根据所述查询格式对查询页面进行渲染,使得页面变为最终需要进行展示的样式。在进行页面渲染后客户端通过加载数据完成最终查询展示。
如图5所示为本说明书一个或多个实施例提供的一种应用于服务器端的查询动态列的实现装置的结构示意图。如图5所示,所述装置包括:
接收单元501,用于接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析单元502,用于解析所述查询参数,确定出需要统计的数据信息;
处理单元503,用于对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
渲染单元504,用于基于所述客户端调用渲染服务,确定出查询格式;
结果单元505,用于将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
图6为本说明书一个或多个实施例提供的一种应用于服务器端的查询动态列的实现设备的结构示意图。如图6所示,所述设备包括:
至少一个处理器601;以及,
与所述至少一个处理器通信连接的存储器602;其中,
所述存储器602存储有可被所述至少一个处理器601执行的指令,所述指令被所述至少一个处理器601执行,以使所述至少一个处理器601能够:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
图7为本说明书一个或多个实施例提供的一种应用于服务器端的查询动态列的实现介质的结构示意图。
如图7所示,本说明书一个或多个实施例提供的一种非易失性计算机存储介质应用于服务器端,存储有计算机可执行指令,所述计算机可执行指令701设置为:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
图8为本说明书一个或多个实施例提供的一种应用于客户端的查询动态列的实现装置的结构示意图。如图8所示,所述装置包括:
发送单元801,用于向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收单元802,用于接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
渲染单元803,用于根据所述动态列信息为参数调用渲染服务,获得查询格式;
结果单元804,用于根据所述查询格式进行页面渲染,完成所述统计数据的加载。
图9为本说明书一个或多个实施例提供的一种应用于客户端的查询动态列的实现设备的结构示意图。如图9所示,所述设备包括:
至少一个处理器901;以及,
与所述至少一个处理器通信连接的存储器902;其中,
所述存储器902存储有可被所述至少一个处理器901执行的指令,所述指令被所述至少一个处理器901执行,以使所述至少一个处理器901能够:
向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
根据所述动态列信息调用渲染服务,获得查询格式;
根据所述查询格式进行页面渲染,完成所述统计数据的加载。
图10为本说明书一个或多个实施例提供的一种应用于客户端的查询动态列的实现介质的结构示意图。如图10所示,所述计算机可执行指令1001设置为:
向服务器端发送查询请求;其中,所述查询请求包括查询参数;
接收动态列信息和统计数据;其中,所述动态列信息和统计数据是经过所述服务器端的加工处理得到的;
根据所述动态列信息调用渲染服务,获得查询格式;
根据所述查询格式进行页面渲染,完成所述统计数据的加载。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置、设备、非易失性计算机存储介质实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
上述对本说明书特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作或步骤可以按照不同于实施例中的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序才能实现期望的结果。在某些实施方式中,多任务处理和并行处理也是可以的或者可能是有利的。
以上所述仅为本说明书的一个或多个实施例而已,并不用于限制本说明书。对于本领域技术人员来说,本说明书的一个或多个实施例可以有各种更改和变化。凡在本说明书的一个或多个实施例的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本说明书的权利要求范围之内。
Claims (7)
1.一种查询动态列的实现方法,其特征在于,所述方法应用于服务器端,该方法包括:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;其中,所述解析所述查询参数,确定出需要统计的数据信息,具体包括:
确定预先建立的查询对象,并对应所述查询对象新增处理单元;
在所述处理单元中,解析所述查询参数;
根据所述查询参数的排列组合,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
2.根据权利要求1所述的方法,其特征在于,所述处理单元包括分页处理单元、汇总合计处理单元、排序处理单元、分组合计处理单元、数据格式化处理单元以及内置取数逻辑处理单元中的一项或多项。
3.根据权利要求1所述的方法,其特征在于,所述对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,具体包括:
对所述需要统计的数据信息进行加工处理;
将所述处理单元添加到执行队列中,以便内置的查询框架在执行查询流程时,自动处理执行队列中的处理单元,确定出动态列信息和统计数据。
4.根据权利要求1所述的方法,其特征在于,所述基于所述客户端调用渲染服务,确定出查询格式,具体包括:
基于所述客户端通过所述动态列信息调用所述渲染服务;
确定所述渲染服务默认的查询格式信息;
将所述默认的查询格式信息与所述动态列信息进行merge操作,确定出所述查询格式。
5.根据权利要求4所述的方法,其特征在于,所述将所述默认的查询格式信息与所述动态列信息进行merge操作,确定出所述查询格式,具体包括:
将所述默认的查询格式信息显示的列信息与所述动态列信息进行合并,得到需要统计和展示的数据列;
根据所述需要统计和展示的数据列得到对应的列信息;其中,所述列信息包括绑定字段、列的宽度、字体、字号中的一项或多项;
根据所述列信息确定出所述查询格式。
6.一种查询动态列的实现装置,应用于服务器端,其特征在于,所述装置包括:
接收单元,用于接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析单元,用于解析所述查询参数,确定出需要统计的数据信息;其中,所述解析所述查询参数,确定出需要统计的数据信息,具体包括:
确定预先建立的查询对象,并对应所述查询对象新增处理单元;
在所述处理单元中,解析所述查询参数;
根据所述查询参数的排列组合,确定出需要统计的数据信息;
处理单元,用于对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
渲染单元,用于基于所述客户端调用渲染服务,确定出查询格式;
结果单元,用于将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
7.一种查询动态列的实现设备,应用于服务器端,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
接收客户端发送的查询请求;其中,所述查询请求包括查询参数;
解析所述查询参数,确定出需要统计的数据信息;其中,所述解析所述查询参数,确定出需要统计的数据信息,具体包括:
确定预先建立的查询对象,并对应所述查询对象新增处理单元;
在所述处理单元中,解析所述查询参数;
根据所述查询参数的排列组合,确定出需要统计的数据信息;
对所述需要统计的数据信息进行加工处理,确定出动态列信息和统计数据,并将所述动态列信息和所述统计数据发送至所述客户端;
基于所述客户端调用渲染服务,确定出查询格式;
将所述查询格式发送至所述客户端,以便所述客户端通过加载所述查询格式进行页面渲染,完成所述统计数据的加载。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110206502.XA CN112883082B (zh) | 2021-02-24 | 2021-02-24 | 一种查询动态列的实现方法、装置及设备 |
PCT/CN2021/082373 WO2022178931A1 (zh) | 2021-02-24 | 2021-03-23 | 一种查询动态列的实现方法、装置及设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110206502.XA CN112883082B (zh) | 2021-02-24 | 2021-02-24 | 一种查询动态列的实现方法、装置及设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112883082A CN112883082A (zh) | 2021-06-01 |
CN112883082B true CN112883082B (zh) | 2023-04-14 |
Family
ID=76054298
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110206502.XA Active CN112883082B (zh) | 2021-02-24 | 2021-02-24 | 一种查询动态列的实现方法、装置及设备 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN112883082B (zh) |
WO (1) | WO2022178931A1 (zh) |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102819424A (zh) * | 2011-12-27 | 2012-12-12 | 金蝶软件(中国)有限公司 | 表格查询中动态构造查询窗体的方法及装置 |
CN103177057A (zh) * | 2011-12-20 | 2013-06-26 | Sap股份公司 | 用于内存列存储数据库的多核算法 |
CN109325053A (zh) * | 2018-06-29 | 2019-02-12 | 平安科技(深圳)有限公司 | 报表系统的数据处理方法、装置及计算机可读存储介质 |
Family Cites Families (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101401062A (zh) * | 2006-02-16 | 2009-04-01 | 移动容量网络公司 | 确定相关来源、查询及合并多个内容来源的结果的方法和系统 |
CN101727624A (zh) * | 2009-12-17 | 2010-06-09 | 中国电力科学研究院 | 一种展现任务列表的方法及系统 |
US9569511B2 (en) * | 2011-08-25 | 2017-02-14 | Salesforce.Com, Inc. | Dynamic data management |
US10719836B2 (en) * | 2011-09-16 | 2020-07-21 | Amobee, Inc. | Methods and systems for enhancing web content based on a web search query |
US9256641B1 (en) * | 2013-10-18 | 2016-02-09 | Ca, Inc. | Dynamic optimization of data aggregation |
US10127206B2 (en) * | 2014-07-16 | 2018-11-13 | Oracle International Corporation | Dynamic column groups in excel |
TWI712899B (zh) * | 2015-07-28 | 2020-12-11 | 香港商阿里巴巴集團服務有限公司 | 資訊查詢方法及裝置 |
CN108763527A (zh) * | 2018-05-31 | 2018-11-06 | 北京明朝万达科技股份有限公司 | 一种业务数据的搜索方法和装置 |
CN108985981B (zh) * | 2018-06-28 | 2021-04-23 | 北京奇虎科技有限公司 | 数据处理系统及方法 |
CN110211646B (zh) * | 2019-05-22 | 2021-04-06 | 浙江大学 | 一种基于OCQL与openEHR的动态可配置医疗报表生成方法 |
CN110276059B (zh) * | 2019-06-24 | 2023-10-27 | 银联商务股份有限公司 | 一种动态报表的处理方法和装置 |
CN111177231B (zh) * | 2019-12-20 | 2023-09-22 | 中国建设银行股份有限公司 | 报表生成方法和报表生成装置 |
CN111597238A (zh) * | 2020-06-10 | 2020-08-28 | 北京明朝万达科技股份有限公司 | 一种基于数据库的动态展示表格数据的方法及装置 |
-
2021
- 2021-02-24 CN CN202110206502.XA patent/CN112883082B/zh active Active
- 2021-03-23 WO PCT/CN2021/082373 patent/WO2022178931A1/zh active Application Filing
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103177057A (zh) * | 2011-12-20 | 2013-06-26 | Sap股份公司 | 用于内存列存储数据库的多核算法 |
CN102819424A (zh) * | 2011-12-27 | 2012-12-12 | 金蝶软件(中国)有限公司 | 表格查询中动态构造查询窗体的方法及装置 |
CN109325053A (zh) * | 2018-06-29 | 2019-02-12 | 平安科技(深圳)有限公司 | 报表系统的数据处理方法、装置及计算机可读存储介质 |
Non-Patent Citations (1)
Title |
---|
WPF中DataGrid 动态增加列;习明然;《CSDN博客》;20190904;全文 * |
Also Published As
Publication number | Publication date |
---|---|
WO2022178931A1 (zh) | 2022-09-01 |
CN112883082A (zh) | 2021-06-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112328224B (zh) | 业务接口的对接方法、装置、存储介质以及电子设备 | |
CN111506849B (zh) | 页面生成方法及装置 | |
CN110647512A (zh) | 一种数据存储和分析方法、装置、设备和可读介质 | |
CN107515875A (zh) | 数据查询方法及装置 | |
CN113268500B (zh) | 业务处理方法、装置及电子设备 | |
CN111460011A (zh) | 页面数据展示方法、装置、服务器及存储介质 | |
CN112396462A (zh) | 基于Clickhouse的人群圈选方法及装置 | |
CN113835692A (zh) | 字典的数据处理方法、装置、电子设备及计算机存储介质 | |
US9298686B2 (en) | System and method for simulating discrete financial forecast calculations | |
CN110287241B (zh) | 一种生成告警数据报表的方法及装置 | |
CN114936154A (zh) | 测试用例和测试数据的生成方法及装置 | |
US11163725B1 (en) | Personalized user interface systems and methods | |
CN112883082B (zh) | 一种查询动态列的实现方法、装置及设备 | |
CN107977459B (zh) | 报表生成方法及装置 | |
CN115438995B (zh) | 一种基于知识图谱的服装定制企业的业务处理方法及设备 | |
WO2023220973A1 (zh) | 数据处理方法、装置、电子设备和计算机可读存储介质 | |
CN114168624A (zh) | 数据分析方法、计算设备及存储介质 | |
CN112948441A (zh) | 一种面向财务数据的多维数据归集方法及设备 | |
CN112527917A (zh) | 一种数据处理的方法和装置 | |
CN111427922A (zh) | 基于分布式架构的数据分析方法、系统、装置及存储介质 | |
CN110659960A (zh) | 变革管理服务产品自动生成方法、服务器及变革管理系统 | |
US20150242913A1 (en) | Enterprise price quote generation | |
CN112100994A (zh) | 一种基于Excel的报表展示方法及装置 | |
CN113935301B (zh) | 一种报表生成方法及装置、存储介质及电子设备 | |
CN111126015B (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 | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20230316 Address after: 250101 Inspur science and Technology Park, 1036 Inspur Road, hi tech Zone, Jinan City, Shandong Province Applicant after: Inspur Genersoft Co.,Ltd. Address before: 250101 Inspur science and Technology Park, 1036 Inspur Road, hi tech Zone, Jinan City, Shandong Province Applicant before: SHANDONG INSPUR GENESOFT INFORMATION TECHNOLOGY Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |