集算报表的本地计算

本文介绍了润乾集算报表的本地计算方案,以减轻数据库压力并提高系统性能。通过将部分计算任务移到报表服务器,利用应用服务器的计算能力,实现了数据存储和计算的本地化,降低了数据库的负载。并通过一个实际案例展示了如何通过集算报表实现本地化计算,以提升报表应用系统的性能。
摘要由CSDN通过智能技术生成

数据统计分析软件有哪些?哪个数据统计分析软件比较好?这是很多人的疑问。其实在报表项目中,常常会碰到数据库压力很大影响整个系统性能的问题。由下面的传统方案的结构示意图可以看出,所有源数据的存储和计算都放在数据库完成。当并发访问量较大的时候,虽然每个报表的数据量不大,还是会造成数据库压力过大,成为性能的瓶颈。多数数据库厂商提供的jdbc接口传输数据比较缓慢,在并发量较大的情况,对报表系统性能的影响也非常明显。

 


这种情况时可以考虑采用润乾集算报表提供的本地计算方案。

所谓本地计算,是将一部分计算任务从数据库移出到报表服务器中完成。大多数有一定规模的应用系统中,数据库和应用服务器通常会部署在不同的物理机器上。其中,数据库处于中心地位,要为各个应用系统提供服务。如果运算大部分由数据库完成,则会导致数据库压力过大,而数据库的扩容成本和难度都相当高。而应用服务器则不同,不同应用会有不同的应用服务器硬件,且容易集群扩容。如果能将一部分运算移出数据库,转而由与应用服务器一起部署的报表服务器完成,则会很大程度地减轻数据库压力,并且充分利用应用服务器所在机器的计算能力,提升系统性能。集算报表方案结构示意图如下:


从上图可以看出,润乾集算报表可以将部分数据从数据库转移到报表应用服务器的本地硬盘。这部分数据可以是计算的中间结果,也可以是部分基础数据。集算报表内置了集算引擎,可以通过简洁的脚本进行本地化的数据计算。因此,从数据存储和计算两方面都可以降低数据库压力。

部分数据和计算从数据库转移到报表应用服务器上,可以充分利用应用服务器集群的存储和计算能力。应用服务器无论是单机升级(纵向扩展)或者增加集群数量(横向扩展)都要比数据库服务器的成本低很多。在本地硬盘上读取数据的速度要比数据库jdbc快很多,可以解决这个瓶颈问题。集算引擎还可以进行多线程的并行计算,可以充分发挥应用服务器多cpu、多核的计算能力。因此,润乾集算报表方案是低成本提高报表应用系统性能的优选方案。

下面,通过“某公司客户累计销售额与去年全年销售额对比报表”的制作,来看一下集算报表是如何实现本地化计算的。报表如下图:

 

这张报表中,20101-10月的客户、订单数、销售额直接来自数据库。2009年全年的订单数、销售额是从报表应用服务器文件系统的temp2009sales.b文件中读取的。“销售额/去年销售额”则是今年和去年的数据共同计算的。报表上部的查询按钮是集算报表提供的“参数模板”功能,具体做法参见教程,这里不再赘述。

首先,要提前用集算器从数据库中读取2009年等各个年份的销售数据,计算好之后,以集算器的二进制编码导出到temp2009sales.b文件中,每年一个文件。中间数据制作好之后,数据库中2009年的数据就可以移除备份了,不再占用数据库的空间。

第二,编写集算器脚本salesProportion.dfx如下:

注意,脚本的参数是:argyear(要查询的年份),argmonth(要查询的月份)。

 

A

1

=connect("db")

2

=A1.query("select client,count(orderid) c,sum(amount) s from sales where year(orderdate)=? and month(orderdate)<=? group by client",argyear,argmonth)

3

=file("D:/files/salesproportion /temp"+string(argyear-1)+"sales.b").import@b()

4

=A3.align(A2:CLIENT,CLIENT)

5

=A2.new(CLIENT,C:COUNT,S:TOTAl,A4(#).C:lastCOUNT,A4(#).S:lastTOTAL,S/A4(#).S:PROPORTION)

6

=A1.close()

7

result A5

A1:连接预先配置好的数据源demo

A2:从数据库中计算取出要查询的年份订单数、销售额。

A3:从前一年的数据文件中取出数据。

A4:将A3中的数据按照A2中的CLIENT字段对齐,A2中有A3中没有的补空行。

A5:利用A2来生成新的续表。其中增加了A4的对应行数据,比如A4(#).C:lastCOUNT就是A4的对应行(#A2的当前行号)的字段C

A6:关闭数据库连接。

A7:向报表返回结果集。

第三,在集算报表中定义报表参数(argyearargmonth)和计算数据集:

 

上图中,参数名是指dfx定义的参数名称,参数值是指报表提交给集算引擎的值。这里是将报表的两个参数的值传递给集算器的同名参数。

第四,设计报表,如下图:

 

输入参数计算后,即可得到前面希望的报表。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值