润乾集算器与帆软报表集成 (直接通过 jdbc,类 DB 存储过程方式调用)
集算器概述
集算器作为一种大数据计算工具,不仅在润乾产品体系中能发挥它的巨大作用,在其他绝大部分数据处理、数据计算领域的项目、产品中,也都有他助力计算的身影。比如传统的报表工具,报表项目中,80% 的报表可以轻松做出来,20% 的因为有大数据量,或者是多样性的非常规数据来源及去向,这时候就需要占用项目很多的时间去做二次开发支持了,通过集算器则可以轻松的解决这些问题。这 20% 的困难问题,几乎所有的报表厂商都会有,润乾可以用集算器来解决,其他报表厂商,也同样可以用集算器来解决,以此来省去那些占整个项目工期比例最多的二次开发的工作量。
加入集算器的传统报表应用结构
这是引入了集算器后报表应用的体系结构图,从图中可以看到,比传统报表应用结构中多了一个计算层:数据源的数据先经过计算层的计算,再传给呈现层去展现。
润乾集算器与帆软报表应用集成
接下来的内容,我们将以帆软报表工具为例,介绍如何将集算器引入到其报表应用的体系结构中。
友情提示:集算器与帆软的集成不需要写任何代码,可直接通过 jdbc 方式调用集算器文件。集算器处理后的数据可直接用作帆软报表数据集。
一、与帆软的报表应用做集成(实际也可称为部署集算器 JDBC)
1,加载需要用到的 jar 包
集算器(以 20220922 发布的标准版为例)安装路径 esProc\lib 下,需要引入三个基础 jar 包:
esproc-bin-xxxx.jar 集算器计算引擎及JDBC驱动包
icu4j_60.3.jar 处理国际化
jdom-1.1.3.jar 解析配置文件
注:除基础包外,还有一些特定功能的 jar,比如要在集算器 JDBC 中读写 Microsoft Office 文件,则需要加入 poi*.jar、xmlbeans-x.x.x.jar 等。
将以上三个基础 jar 放置到 [帆软设计器安装路径]\WebReport\WEB-INF\lib 下。
2,部署 xml 配置文件
配置文件:raqsoftConfig.xml。
可以在 [集算器安装目录]\esProc\config 目录下找到。
复制后放置在帆软的报表应用类路径下,即 [帆软安装目录]\webapps\webroot\WEB-INF\classes。
注意:当集算器中要引用数据连接时,要在 raqsoftConfig.xml 增加对应配置。
PS: JDBC 集成也可参考官方文档,http://d.raqsoft.com.cn:6999/esproc/tutorial/jdbcbushu.html
二、开发并部署集算器 splx 脚本文件
我们这里以脚本读取 Excle 文件数据为例,读取后展现,简单示例一下。
Excel 内容如下
集算器脚本
其中,A1 读取 Excel 文件并将第一个 sheet 页的数据读入且第一行作为字段名称行。
注:Excel 或其他数据文件路径可以是绝对也可以是相对。
部署: splx 脚本文件放至 应用类路径下,如帆软设计器安装目录的 WebReport\WEB-INF\classes 下
三、帆软报表设计器内定义集算器(jdbc 方式)数据连接
配置如下(集算器作为逻辑数据库调用)
测试连接,成功即可。
PS: 如连接失败,可在“高级”内,将“获取连接前校验”改为“否”。
四、帆软设计器设计报表并调用集算器文件 (splx) 生成数据集
1,新建工作簿并添加”数据库查询”类数据集
注意调用方法: call 集算器文件名 ()。带有参数的也可以调用,如 call FR_lmysql(${hh}),其中 hh 是定义在报表模板要传给集算器的参数名。
数据集加载后效果(字段名全部列出)
Ps_:在编辑数据集页面,切换到集算器数据连接 会报连接失败,不用管它(后续查出原因再修改),可正常调用。
2,设计简单的网格报表
五、WEB 端报表效果
六、总结
集算器与帆软报表集成后,集算器类似作为一个本地的逻辑数据库,采用存储过程模式调用集算器文件即可,无需任何二次开发代码。
因此,集算器作为一种大数据计算工具,不仅在润乾产品体系中能发挥它的巨大作用,也可为其他的报表工具、产品或项目在数据处理、数据计算提供强有力的帮助。如与帆软报表的集成中,不仅可以为其报表呈现提供数据准备,还能优化整个应用结构。
更多集成部署相关问题请查看:集成部署相关问题分类导航
* 润乾与 springBoot 集成
* 润乾报表在非 windows 操作系统下图形环境问题
* 轻松实现报表集成
* 如何将润乾报表内置 tomcat 升级到 tomcat9
* tomcat8 部署润乾 v2018 完整过程
* linux 操作系统安装润乾报表
* jboss7.1.1 下部署润乾报表 2018 详细步骤