CN117521619B - 基于下位机的报表生成方法、计算机设备与存储介质 - Google Patents
基于下位机的报表生成方法、计算机设备与存储介质 Download PDFInfo
- Publication number
- CN117521619B CN117521619B CN202410009303.3A CN202410009303A CN117521619B CN 117521619 B CN117521619 B CN 117521619B CN 202410009303 A CN202410009303 A CN 202410009303A CN 117521619 B CN117521619 B CN 117521619B
- Authority
- CN
- China
- Prior art keywords
- partition
- storage node
- data
- target
- water
- 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
- 238000003860 storage Methods 0.000 title claims abstract description 249
- 238000000034 method Methods 0.000 title claims abstract description 48
- 238000005192 partition Methods 0.000 claims abstract description 369
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 claims abstract description 163
- 238000009826 distribution Methods 0.000 claims abstract description 10
- 238000013500 data storage Methods 0.000 claims description 15
- 238000012545 processing Methods 0.000 claims description 15
- 238000004590 computer program Methods 0.000 claims description 14
- 230000004044 response Effects 0.000 claims description 14
- 238000004519 manufacturing process Methods 0.000 description 6
- 238000010586 diagram Methods 0.000 description 3
- 238000000638 solvent extraction Methods 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 210000004556 brain Anatomy 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 239000012141 concentrate Substances 0.000 description 1
- 239000003814 drug Substances 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 238000012797 qualification Methods 0.000 description 1
- 239000000126 substance Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Classifications
-
- 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/903—Querying
- G06F16/90335—Query processing
-
- 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
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Computational Linguistics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Audiology, Speech & Language Pathology (AREA)
- General Health & Medical Sciences (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Databases & Information Systems (AREA)
- Data Mining & Analysis (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本公开的实施例公开了基于下位机的报表生成方法、计算机设备与存储介质。该方法的一具体实施方式包括:目标下位机采集预设时间段内水务系统的水量数据序列;对水量数据序列进行初始化处理,得到初始化水量数据信息,以及将初始化水量数据信息发送至目标上位机中;目标上位机响应于接收到目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表;根据预设的分布数据表,确定水务数据报表中每条水务数据对应的数据分区,得到数据分区集。该实施方式提升了报表的生成效率。
Description
技术领域
本公开的实施例涉及计算机领域,具体涉及基于下位机的报表生成方法、计算机设备与存储介质。
背景技术
工业自动化控制是实现我国工业化,规模化、自动化的核心,目前国内几乎所有的工厂都配备了自动化控制生产线,可以大大提高生产效率、节约操作人员精力、集成各类故障判断和安全联锁保护。对于一个工厂来说,自动化系统就是全厂最为核心的大脑,它决定了产品的品质,决定了处理物质的合格程度,决定了能源药剂消耗的经济性,所以自动化系统对于工厂的稳定运行、安全运行、经济运行、达标运行有着举足轻重的作用。
作为生产型企业,报表对于企业生产有着指导意义,企业可以根据报表获得基础数据用于研判系统的性能、处理能力及各项指标,是企业日常生产最为重要的数据。同时报表也是目前国内自动化控制系统实施的难点和痛点,这点从国内数量众多的生产报表软件开发公司就可以看出。
目前,企业对于报表的生成,通常采用的方式为:通过上位机配合数据库进行完成对报表的制作生成。然而,采用上述方式,通常存在以下技术问题:需要专业的技术人员操控上位机与数据库,造成报表的生成效率较低;此外,难以对报表中的各条数据进行分类归档,在进行数据查询与分析时,需要对报表进行遍历,导致数据查询与分析的时间较长。
发明内容
本公开的内容部分用于以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。本公开的内容部分并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。
本公开的一些实施例提出了基于下位机的报表生成方法、计算机设备和计算机可读存储介质,来解决以上背景技术部分提到的技术问题。
第一方面,本公开的一些实施例提供了一种基于下位机的报表生成方法,该方法包括:目标下位机采集预设时间段内水务系统的水量数据序列;上述目标下位机对上述水量数据序列进行初始化处理,得到初始化水量数据信息,以及将上述初始化水量数据信息发送至相关联的目标上位机中;上述目标上位机响应于接收到上述目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将上述初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表;上述目标上位机根据预设的分布数据表,确定上述水务数据报表中每条水务数据对应的数据分区,得到数据分区集,其中,每个数据分区对应有初始存储节点分区组;上述目标上位机对于上述数据分区集中的每一个数据分区,执行处理步骤:从上述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组,其中,上述存储节点分区组为通过水务数据子表写入至上述数据分区对应的初始存储节点分区组得到的,上述水务数据子表与上述数据分区相关联;对上述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组;基于所生成的各个目标存储节点子分区组,生成对应上述水务数据的数据存储结果;上述目标上位机响应于接收到对应目标水务数据的数据查询请求,生成对应上述目标水务数据的查询结果,以及将上述查询结果发送至相关联的查询终端。
第二方面,本公开还提供一种计算机设备,上述计算机设备包括处理器、存储器、以及存储在上述存储器上并可被上述处理器执行的计算机程序,其中上述计算机程序被上述处理器执行时,实现如上述第一方面任一实现方式所描述的方法。
第三方面,本公开还提供一种计算机可读存储介质,上述计算机可读存储介质上存储有计算机程序,其中上述计算机程序被处理器执行时,实现如上述第一方面任一实现方式所描述的方法。
本公开的上述各个实施例具有如下有益效果:通过本公开的一些实施例的基于下位机的报表生成方法,提升了报表的生成效率。首先,目标下位机采集预设时间段内水务系统的水量数据序列。由此,可以通过简单的下位机,对水量数据进行采集。其次,上述目标下位机对上述水量数据序列进行初始化处理,得到初始化水量数据信息,以及将上述初始化水量数据信息发送至相关联的目标上位机中。由此,可以通过下位机直接对水量数据进行处理,以提升报表的生成效率。接着,上述目标上位机响应于接收到上述目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将上述初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表。由此,上位机在接收到处理后的水务数据之后,可以直接生成报表,简化了报表生成的步骤。然后,上述目标上位机根据预设的分布数据表,确定上述水务数据报表中每条水务数据对应的数据分区,得到数据分区集。其中,每个数据分区对应有初始存储节点分区组。之后,上述目标上位机对于上述数据分区集中的每一个数据分区,执行处理步骤:从上述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组,其中,上述存储节点分区组为通过水务数据子表写入至上述数据分区对应的初始存储节点分区组得到的,上述水务数据子表与上述数据分区相关联;对上述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组;基于所生成的各个目标存储节点子分区组,生成对应上述数据分区的数据存储结果。最后,上述目标上位机响应于接收到对应目标水务数据的数据查询请求,生成对应上述目标水务数据的查询结果,以及将上述查询结果发送至相关联的查询终端。由此,通过将原来水务数据报表拆分成设定数据量的分区,可以使得各个分区间的数据分布较为均衡,单个或多个机器节点上的存储磁盘得以有效利用。从而,使得水务数据分布均匀,利于负载均衡。
附图说明
结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,元件和元素不一定按照比例绘制。
图1是根据本公开的基于下位机的报表生成方法的一些实施例的流程图;
图2是本公开实施例提供的一种计算机设备的结构示意性框图。
具体实施方式
下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例。相反,提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。在不冲突的情况下,本公开中的实施例及实施例中的特征可以相互组合。
需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
下面将参考附图并结合实施例来详细说明本公开。
图1是根据本公开的基于下位机的报表生成方法的一些实施例的流程图。示出了根据本公开的基于下位机的报表生成方法的一些实施例的流程100。该基于下位机的报表生成方法,包括以下步骤:
步骤101,目标下位机采集预设时间段内水务系统的水量数据序列。
在一些实施例中,目标下位机可以采集预设时间段内水务系统的水量数据序列。目标下位机可以是指安装在水务系统中用于采集水量数据的可编程逻辑控制器(PLC)。水务系统中可以包含多个水务设备,每一水务设备独自供水。例如,水务设备可以是水厂的供水设备。预设时间段可以是预设设定的时间段。例如,预设时间段可以是当前时间的7天之前到现在的时间段。水量数据可以包括:进水量组、出水量组、浓水量组与产水率组等。一个进水量/出水量/浓水量/产水率对应一个水务设备。一个水量数据对应一个单位时间。诸如,单位时间可以是指预设时间段中的一个最小的时长单位。例如,单位时间可以是1天。
步骤102,上述目标下位机对上述水量数据序列进行初始化处理,得到初始化水量数据信息,以及将上述初始化水量数据信息发送至相关联的目标上位机中。
在一些实施例中,上述目标下位机可以对上述水量数据序列进行初始化处理,得到初始化水量数据信息,以及将上述初始化水量数据信息发送至相关联的目标上位机中。初始化处理可以包括:求和、作差、计算百分比等处理。例如,对于某一水务设备在预设时间段内的各个水量数据进行求和/作差等处理。再例如,可以对于各个水务设备在预设时间段内的各个水量数据进行求和/作差等处理。例如,先计算每个水务设备在预设时间段内的各个出水量的总和,再对每两个水务设备之间的出水量的总和进行作差或计算百分比等处理。相关联的目标上位机可以是指与目标下位机通信连接的计算设备。例如,目标上位机可以是指WINCC上位机。
步骤103,上述目标上位机响应于接收到上述目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将上述初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表。
在一些实施例中,上述目标上位机可以响应于接收到上述目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将上述初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表。各个表格字段名可以包括但不限于:进水量、出水量、浓水量、产水率、单一水务设备进水量总和、单一水务设备出水量总和、单一水务设备浓水量总和、单一水务设备平均产水率等。各个表格字段名可以是指水务数据空表的各个字段名。例如,可以将上述初始化水量数据信息包括的各个数据,按照对应的表格字段名,填写至水务数据空表中,得到水务数据报表。
步骤104,上述目标上位机根据分布数据表,确定上述水务数据报表中每条水务数据对应的数据分区,得到数据分区集。
在一些实施例中,根据分布数据表,上述目标上位机可以确定上述水务数据报表中每条水务数据对应的数据分区,得到数据分区集。其中,每个数据分区对应有初始存储节点分区组。上述分布数据表可以是用于OLAP(Online Analytical Processing)联机分析处理业务的分布式表。上述分布数据表可以关联有数据分区集。数据分区可以是指数据分片。数据分区可以是指对上述目标数据表进行逻辑划分得到的分表。数据分区不占用物理地址控件。数据分区存在对应的分区标识。一个分区标识对应一个表格字段名。从而,可以确定水务数据对应的数据分区。存储节点分区可以是对上述目标数据表进行物理划分得到的、未导入水务数据的分表。每个存储节点分区占用物理地址空间。例如,对于每条水务数据,上述目标上位机可以通过预设的分区方法,将从上述数据分区集中分片出一个数据分区给水务数据。例如,分区方法可以是随机分区。
步骤105,上述目标上位机对于上述数据分区集中的每一个数据分区,执行处理步骤:
步骤1051,从上述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组。
在一些实施例中,上述目标上位机可以从上述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组。其中,上述存储节点分区组为通过水务数据子表写入至上述数据分区对应的初始存储节点分区组得到的,上述水务数据子表与上述数据分区相关联。上述预设条件可以是存储节点分区中分区数据的数量大于预设数量阈值。分区数据可以是对应分区中的数据。上述分区数据可以包括:原始水务数据和写入后的水务数据。上述原始水务数据可以是在未写入水务数据子表之前,对应的存储节点分区已存储的数据。上述写入后的水务数据可以是存储节点分区写入的水务数据子表中的数据。水务数据子表可以是水务数据报表的子表。例如,首先,上述目标上位机可以通过设定的数据写入方法,将上述数据分区对应的、水务数据子表写入至上述数据分区对应的初始存储节点分区组中,得到存储节点分区组。数据写入方法可以是单一数据写入方法。例如,可以将水务数据一个一个写入任一初始存储节点分区。然后,可以从上述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组。
可选地,响应于确定到上述存储节点分区组中不存在符合预设条件的存储节点分区,将上述存储节点分区组与对应的各个分区数据确定为数据存储结果。
在一些实施例中,上述执行主体可以响应于确定到上述存储节点分区组中不存在符合预设条件的存储节点分区,将上述存储节点分区组与对应的各个分区数据确定为数据存储结果。一个存储节点分区对应一个分区数据。
步骤1052,对上述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组。
在一些实施例中,上述目标上位机可以对上述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组。其中,目标存储节点子分区可以是目标存储节点分区对应的子分区。子分区可以是数据分区对应的子表。
在一个实际的应用场景中,上述目标上位机可以通过以下步骤对上述目标存储节点分区组中的每个目标存储节点分区进行分裂处理:
第一步,根据上述目标存储节点分区,生成分区分裂数。其中,上述分区分裂数可以是对目标存储节点分区进行分裂后得到的子分区的数量。可以将上述目标存储节点分区对应的分区数据数量与上述预设数量阈值的比值确定为数量比值。然后,将上述数量比值向上取整,得到分区分裂数。
第二步,根据上述分区分裂数,构建初始目标存储节点子分区组。其中,初始目标存储节点子分区可以是上述目标存储节点分区对应的、未写入任何数据的子分区。每个初始目标存储节点子分区对应有子分区标识。可以通过数据库分区操作,创建分区分裂数个始目标存储节点子分区,得到初始目标存储节点子分区组。
第三步,将上述目标存储节点分区对应的分区数据写入至上述初始目标存储节点子分区组中,得到目标存储节点子分区组。可以通过上述数据写入方法,将上述目标存储节点分区对应的分区数据写入至初始目标存储节点子分区组中,得到目标存储节点子分区组。
进一步地,响应于接收到离线水务数据报表,确定上述离线水务数据报表对应的离线数据分区组。
在一些实施例中,上述目标上位机可以响应于接收到离线水务数据报表,确定上述离线水务数据报表对应的离线数据分区组。其中,上述离线水务数据报表表示对应上述水务数据报表的离线水务数据报表。例如,首先,可以对于上述离线水务数据报表中的、每个离线水务数据,通过预设的分区方法,从上述数据分区集中选出一个数据分区,作为离线水务数据对应的离线数据分区。从而,得到离线数据分区组。
进一步地,响应于确定离线初始存储节点分区组中存在目标离线初始存储节点分区,从上述离线初始存储节点分区组中选择出目标离线初始存储节点分区,得到目标离线初始存储节点分区组。
在一些实施例中,上述目标上位机可以响应于确定离线初始存储节点分区组中存在目标离线初始存储节点分区,从上述离线初始存储节点分区组中选择出目标离线初始存储节点分区,得到目标离线初始存储节点分区组。其中,离线初始存储节点分区是上述离线数据分区组对应的、待写入离线水务数据子表的初始存储节点分区,上述离线水务数据子表是上述离线水务数据报表的子表,目标离线初始存储节点分区是数据分区集对应的、未完成分裂的目标存储节点分区。
进一步地,将上述离线初始存储节点分区组与上述目标离线初始存储节点分区组的分区差集确定为关联离线存储节点分区组。
在一些实施例中,上述目标上位机可以将上述离线初始存储节点分区组与上述目标离线初始存储节点分区组的分区差集确定为关联离线存储节点分区组。
进一步地,对于每个目标离线初始存储节点分区,将上述目标离线初始存储节点分区对应的离线水务数据子表写入至上述目标离线初始存储节点分区和对应的初始目标存储节点子分区组中。
在一些实施例中,上述目标上位机可以对于每个目标离线初始存储节点分区,将上述目标离线初始存储节点分区对应的离线水务数据子表写入至上述目标离线初始存储节点分区和对应的初始目标存储节点子分区组中。首先,将上述目标离线初始存储节点分区对应的离线水务数据子表写入上述目标离线初始存储节点分区中。然后,通过上述预设的数据写入方法,将上述目标离线初始存储节点分区对应的离线水务数据子表写入至对应的初始目标存储节点子分区组包括的各个初始目标存储节点子分区中。
进一步地,对于每个关联离线存储节点分区,将上述关联离线存储节点分区对应的离线水务数据子表写入至上述关联离线存储节点分区中。
在一些实施例中,上述目标上位机可以对于每个关联离线存储节点分区,将上述关联离线存储节点分区对应的离线水务数据子表写入至上述关联离线存储节点分区中。例如,可以对于每个关联离线存储节点分区,通过上述数据写入方法,将上述关联离线存储节点分区对应的离线水务数据子表写入至上述关联离线存储节点分区中。
步骤1053,基于所生成的各个目标存储节点子分区组,生成对应上述数据分区的数据存储结果。
在一些实施例中,上述目标上位机可以基于所生成的各个目标存储节点子分区组,生成对应上述数据分区的数据存储结果。其中,上述数据存储结果可以是上述数据分区对应的、写入水务数据的各个目标存储节点子分区与对应的各个分区数据的信息。
在一个实际的应用场景中,上述目标上位机可以通过以下步骤生成对应上述数据分区的数据存储结果:
第一,响应于确定上述存储节点分区组中存在目标未分裂存储节点分区,从上述存储节点分区组中选择出目标未分裂存储节点分区,得到至少一个目标未分裂存储节点分区。
第二,根据上述至少一个目标未分裂存储节点分区和上述各个目标存储节点子分区组,生成上述数据分区对应的数据存储结果。
例如,可以对于每个目标未分裂存储节点分区,将上述目标未分裂存储节点分区与对应的分区数据确定为第一子分区数据写入结果。然后,对于各个目标存储节点子分区组中的每个目标存储节点子分区,将上述目标存储节点子分区与对应的分区数据确定为第二子分区数据写入结果。最后,将各个第一子分区数据写入结果和各个子分区数据写入结果确定为上述数据分区对应的数据存储结果。
步骤106,上述目标上位机响应于接收到对应目标水务数据的数据查询请求,生成对应上述目标水务数据的查询结果,以及将上述查询结果发送至相关联的查询终端。
在一些实施例中,上述目标上位机可以响应于接收到对应目标水务数据的数据查询请求,生成对应上述目标水务数据的查询结果,以及将上述查询结果发送至相关联的查询终端。其中,上述数据查询请求可以是针对上述目标数据表进行数据查询的请求。上述数据查询请求可以包括查询字段。相关联的查询终端可以是发送数据查询请求的终端。
在一个实际的应用场景中,上述目标上位机可以通过以下步骤生成对应上述目标水务数据的查询结果:
第一,确定上述查询请求对应的查询数据分区。可以根据数据查询请求包括的查询字段,从上述数据分区组中选出一个数据分区,作为查询数据分区。
第二,响应于确定上述查询数据分区存在对应的目标查询存储节点分区,将至少一个查询存储节点分区与至少一个目标查询存储节点分区的分区差集确定为关联存储节点分区组。其中,目标查询存储节点分区是与上述查询数据分区对应的目标存储节点分区,查询存储节点分区是对应上述数据分区的存储节点分区。首先,可以将上述查询数据分区对应的至少一个存储节点分区确定为至少一个查询存储节点分区。然后,响应于确定上述查询数据分区存在对应的目标存储节点分区,从上述目标查询虚拟分片对应的各个存储节点分区中选出目标存储节点分区,作为目标查询存储节点分区,得到至少一个目标查询存储节点分区。最后,将至少一个查询存储节点分区与至少一个目标查询存储节点分区的分区差集确定为关联存储节点分区组。
第三,基于上述关联存储节点分区组,执行数据查询操作,得到查询结果。首先,响应于确定上述目标存储节点分区组分裂处理未完成,从上述目标存储节点分区组中、选出已分裂完成的目标存储节点分区,作为分裂存储节点分区,得到分裂存储节点分区组。然后,根据上述关联存储节点分区组和上述分裂存储节点分区组,执行数据查询操作,得到查询结果。例如,首先,可以将上述关联存储节点分区组中的每个关联存储节点分区、上述分裂存储节点分区组对应的每个目标存储节点子分区确定为待查询存储节点子分区,得到待查询存储节点子分区组。然后,对于上述待查询存储节点子分区组中的每个待查询存储节点子分区,根据上述数据查询请求包括的查询字段,对上述待查询存储节点子分区对应的分片数据执行数据查询操作,得到分区数据查询结果。然后,将所得到的各个分区数据查询结果确定为数据查询结果。
对于背景技术提及的“难以对报表中的各条数据进行分类归档,在进行数据查询与分析时,需要对报表进行遍历,导致数据查询与分析的时间较长。”。可以通过以下步骤解决:首先,确定上述查询请求对应的查询数据分区。然后,响应于确定上述查询数据分区存在对应的目标查询存储节点分区,将至少一个查询存储节点分区与至少一个目标查询存储节点分区的分区差集确定为关联存储节点分区组。其中,目标查询存储节点分区是与上述查询数据分区对应的目标存储节点分区,查询存储节点分区是对应上述数据分区的存储节点分区。之后,响应于确定上述目标存储节点分区组分裂处理未完成,从上述目标存储节点分区组中、选出已分裂完成的目标存储节点分区,作为分裂存储节点分区,得到分裂存储节点分区组。最后,根据上述关联存储节点分区组和上述分裂存储节点分区组,执行数据查询操作,得到查询结果。由此,针对无需分裂的每个关联存储节点分区、已分裂的各个目标存储节点分区对应的每个目标存储节点子分区同时进行数据查询。由此,可以对数据分区下的、与查询相关的每个存储节点分区同时进行数据查询,以缩短查询时长。从而,可以提高数据查询的效率。
图2为本公开实施例提供的一种计算机设备的结构示意性框图。该计算机设备可以为终端。
如图2所示,该计算机设备包括通过系统总线连接的处理器、存储器和网络接口,其中,存储器可以包括非易失性存储介质和内存储器。
非易失性存储介质可存储操作系统和计算机程序。该计算机程序包括程序指令,该程序指令被执行时,可使得处理器执行任意一种基于下位机的报表生成方法。
处理器用于提供计算和控制能力,支撑整个计算机设备的运行。
内存储器为非易失性存储介质中的计算机程序的运行提供环境,该计算机程序被处理器执行时,可使得处理器执行任意一种基于下位机的报表生成方法。
该网络接口用于进行网络通信,如发送分配的任务等。本领域技术人员可以理解,图2中示出的结构,仅仅是与本公开方案相关的部分结构的框图,并不构成对本公开方案所应用于其上的计算机设备的限定,具体的计算机设备可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
应当理解的是,处理器可以是中央处理单元 (Central Processing Unit,CPU),该处理器还可以是其他通用处理器、数字信号处理器 (Digital Signal Processor,DSP)、专用集成电路 (Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA) 或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
其中,在一个实施例中,上述处理器用于运行存储在存储器中的计算机程序,以实现如下步骤:目标下位机采集预设时间段内水务系统的水量数据序列;上述目标下位机对上述水量数据序列进行初始化处理,得到初始化水量数据信息,以及将上述初始化水量数据信息发送至相关联的目标上位机中;上述目标上位机响应于接收到上述目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将上述初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表;上述目标上位机根据预设的分布数据表,确定上述水务数据报表中每条水务数据对应的数据分区,得到数据分区集,其中,每个数据分区对应有初始存储节点分区组;上述目标上位机对于上述数据分区集中的每一个数据分区,执行处理步骤:从上述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组,其中,上述存储节点分区组为通过水务数据子表写入至上述数据分区对应的初始存储节点分区组得到的,上述水务数据子表与上述数据分区相关联;对上述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组;基于所生成的各个目标存储节点子分区组,生成对应上述数据分区的数据存储结果;上述目标上位机响应于接收到对应目标水务数据的数据查询请求,生成对应上述目标水务数据的查询结果,以及将上述查询结果发送至相关联的查询终端。
本公开实施例还提供一种计算机可读存储介质,上述计算机可读存储介质上存储有计算机程序,上述计算机程序中包括程序指令,上述程序指令被执行时所实现的方法可参照本公开基于下位机的报表生成方法的各个实施例。
其中,上述计算机可读存储介质可以是前述实施例上述的计算机设备的内部存储单元,例如上述计算机设备的硬盘或内存。上述计算机可读存储介质也可以是上述计算机设备的外部存储设备,例如上述计算机设备上配备的插接式硬盘,智能存储卡(SmartMediaCard,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本公开实施例序号仅仅为了描述,不代表实施例的优劣。以上所述,仅为本公开的具体实施方式,但本公开的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本公开揭露的技术范围内,可轻易想到各种等效的修改或替换,这些修改或替换都应涵盖在本公开的保护范围之内。因此,本公开的保护范围应以权利要求的保护范围为准。
Claims (4)
1.一种基于下位机的报表生成方法,其特征在于,所述方法包括:
目标下位机采集预设时间段内水务系统的水量数据序列;
所述目标下位机对所述水量数据序列进行初始化处理,得到初始化水量数据信息,以及将所述初始化水量数据信息发送至相关联的目标上位机中;
所述目标上位机响应于接收到所述目标下位机发送的初始化水量数据信息,按照预先设置的各个表格字段名,将所述初始化水量数据信息填写至预先设置的水务数据空表中,得到水务数据报表;
所述目标上位机根据预设的分布数据表,确定所述水务数据报表中每条水务数据对应的数据分区,得到数据分区集,其中,每个数据分区对应有初始存储节点分区组;
所述目标上位机对于所述数据分区集中的每一个数据分区,执行处理步骤:
从所述数据分区对应的存储节点分区组中选择出符合预设条件的存储节点分区作为目标存储节点分区,得到目标存储节点分区组,其中,所述存储节点分区组为通过水务数据子表写入至所述数据分区对应的初始存储节点分区组得到的,所述水务数据子表与所述数据分区相关联;
对所述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组;
基于所生成的各个目标存储节点子分区组,生成对应所述数据分区的数据存储结果;
所述目标上位机响应于接收到对应目标水务数据的数据查询请求,生成对应所述目标水务数据的查询结果,以及将所述查询结果发送至相关联的查询终端;
其特征在于,所述对所述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组,包括:
根据所述目标存储节点分区,生成分区分裂数;
根据所述分区分裂数,构建初始目标存储节点子分区组;
将所述目标存储节点分区对应的分区数据写入至所述初始目标存储节点子分区组中,得到目标存储节点子分区组;
其特征在于,所述基于所生成的各个目标存储节点子分区组,生成对应所述数据分区的数据存储结果,包括:
响应于确定所述存储节点分区组中存在目标未分裂存储节点分区,从所述存储节点分区组中选择出目标未分裂存储节点分区,得到至少一个目标未分裂存储节点分区;
根据所述至少一个目标未分裂存储节点分区和所述各个目标存储节点子分区组,生成所述数据分区对应的数据存储结果。
2.根据权利要求1所述的方法,其特征在于,在所述对所述目标存储节点分区组中的每个目标存储节点分区进行分裂处理,以生成目标存储节点子分区组之前,所述方法还包括:
响应于确定到所述存储节点分区组中不存在符合预设条件的存储节点分区,将所述存储节点分区组与对应的各个分区数据确定为数据存储结果。
3.一种计算机设备,其中,所述计算机设备包括处理器、存储器、以及存储在所述存储器上并可被所述处理器执行的计算机程序,其中所述计算机程序被所述处理器执行时,实现如权利要求1-2中任一所述的方法的步骤。
4.一种计算机可读存储介质,其中,所述计算机可读存储介质上存储有计算机程序,其中所述计算机程序被处理器执行时,实现如权利要求1-2中任一所述的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202410009303.3A CN117521619B (zh) | 2024-01-04 | 2024-01-04 | 基于下位机的报表生成方法、计算机设备与存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202410009303.3A CN117521619B (zh) | 2024-01-04 | 2024-01-04 | 基于下位机的报表生成方法、计算机设备与存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN117521619A CN117521619A (zh) | 2024-02-06 |
CN117521619B true CN117521619B (zh) | 2024-03-29 |
Family
ID=89763028
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202410009303.3A Active CN117521619B (zh) | 2024-01-04 | 2024-01-04 | 基于下位机的报表生成方法、计算机设备与存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN117521619B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9875272B1 (en) * | 2015-06-23 | 2018-01-23 | Google Inc. | Method and system for designing a database system for high event rate, while maintaining predictable query performance |
CN109241159A (zh) * | 2018-08-07 | 2019-01-18 | 威富通科技有限公司 | 一种数据立方体的分区查询方法、系统及终端设备 |
CN109492052A (zh) * | 2018-10-23 | 2019-03-19 | 中冶南方(武汉)自动化有限公司 | 一种scada分布式历史数据存储方法及系统 |
WO2020215558A1 (zh) * | 2019-04-26 | 2020-10-29 | 平安科技(深圳)有限公司 | 数据存储方法、数据查询方法、装置、设备及存储介质 |
CN116204534A (zh) * | 2023-05-06 | 2023-06-02 | 深圳市华磊迅拓科技有限公司 | 数据归档方法、装置、设备及存储介质 |
-
2024
- 2024-01-04 CN CN202410009303.3A patent/CN117521619B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9875272B1 (en) * | 2015-06-23 | 2018-01-23 | Google Inc. | Method and system for designing a database system for high event rate, while maintaining predictable query performance |
CN109241159A (zh) * | 2018-08-07 | 2019-01-18 | 威富通科技有限公司 | 一种数据立方体的分区查询方法、系统及终端设备 |
CN109492052A (zh) * | 2018-10-23 | 2019-03-19 | 中冶南方(武汉)自动化有限公司 | 一种scada分布式历史数据存储方法及系统 |
WO2020215558A1 (zh) * | 2019-04-26 | 2020-10-29 | 平安科技(深圳)有限公司 | 数据存储方法、数据查询方法、装置、设备及存储介质 |
CN116204534A (zh) * | 2023-05-06 | 2023-06-02 | 深圳市华磊迅拓科技有限公司 | 数据归档方法、装置、设备及存储介质 |
Non-Patent Citations (2)
Title |
---|
基于分级存储环境的数据即时应用产品;何翔 等;计算机系统应用;20160315;第25卷(第3期);第251-256页 * |
数据报表的生成方法;曹淑芬;;科技资讯;20101223(第36期);第10-11页 * |
Also Published As
Publication number | Publication date |
---|---|
CN117521619A (zh) | 2024-02-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108810115B (zh) | 一种适用于分布式数据库的负载均衡方法、装置及服务器 | |
CN112597153B (zh) | 一种基于区块链的数据存储方法、装置及存储介质 | |
CN105786619B (zh) | 虚拟机分配方法及装置 | |
CN110968647A (zh) | 数据存储方法、装置、计算机设备和存储介质 | |
CN111159140B (zh) | 数据处理方法、装置、电子设备及存储介质 | |
CN106407395A (zh) | 数据查询的处理方法及装置 | |
CN115981562A (zh) | 一种数据处理方法及装置 | |
CN104951442A (zh) | 一种确定结果向量的方法和装置 | |
CN113672375A (zh) | 资源分配预测方法、装置、设备及存储介质 | |
CN113051102A (zh) | 文件备份方法、装置、系统、存储介质和计算机设备 | |
CN109634524B (zh) | 一种数据处理守护进程的数据分区配置方法、装置及设备 | |
CN111008071A (zh) | 任务调度系统、方法和服务器 | |
CN117521619B (zh) | 基于下位机的报表生成方法、计算机设备与存储介质 | |
CN113342526A (zh) | 云计算移动网络资源动态管控方法、系统、终端及介质 | |
CN111338778A (zh) | 任务调度方法、装置、存储介质及计算机设备 | |
CN116303418A (zh) | 基于物联网平台的海量规则处理方法、系统及存储介质 | |
CN114020454A (zh) | 一种内存管理方法、装置、设备及介质 | |
CN114443415A (zh) | 用于Prometheus的采集自动均衡方法、任务分配器及系统 | |
CN111885159A (zh) | 数据采集方法、装置、电子设备及存储介质 | |
CN112541038A (zh) | 时序数据管理方法、系统、计算设备及存储介质 | |
CN111428886A (zh) | 一种故障诊断的深度学习模型自适应更新的方法及装置 | |
CN111177530A (zh) | 基于大数据实现热点内容推送的方法及装置 | |
CN106775854B (zh) | 一种生成配置文件的方法和装置 | |
CN104572412A (zh) | 虚拟机开机时数统计方法及系统 | |
CN114860760B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |