1. 描述编辑
相同表结构,不同数据库,希望通过网络报表连接不同数据库的时候,在同一个网络报表里面可以显示结果,这样要怎样实现呢?
2. 原理编辑
通过使用程序网络报表所在类需要继承 com.fr.web.reportlet 这个抽象类,并且需要实现 createReport(ReportletRequest arg0) 这个方法,并返回报表对象。
对返回的报表对象设置新的数据集,通过 putTableData(DSName,tableData) 方法,将定义的数据集添加到报表中,从而改变模板数据。DSName 是定义的数据集名例如 ds1,tableData 是调用连接数据集。
3. 实现步骤编辑
3.1 定义程序数据集
程序数据集可以获取到不同数据库里面的值,或者通过 Java 内部查询的结果放到程序数据集里面,再显示到报表上,具体程序数据集的使用,可参考 程序数据源 文档
3.2 新建将要获取的模板
新建模板 1.cpt,新建数据集 ds2,将 ds2 中的字段拖拽到报表中,模板保存到根目录下,如果不存在下图样式的表可以新建一个,具体设置如下图:
获取的模板 1.cpt,使用的数据集 ds2,里面连接的数据库表的格式必须要跟我们定义的程序数据集里面的列的名字是匹配的例如 Name,Score 这样赋值新的数据集,才可以显示结果。
3.3 定义程序网络报表
具体代码如下所示:
https://git.fanruan.com/demo/example/src/release/10.0/src/main/java/com/fr/demo/NewDateDemo.java
这里要调用 %FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\data 中的 ArrayTableDataDemo 类。
3.3 编译生成类文件
在 Java 开发平台中会自动编译,在此不再详述。
将编译后的 NewDateDemo.class 放到网络报表根目录下,由于该类在包 com.fr.demo 中,因此存放在%FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\demo下。
3.4 发布并 Web 预览
保存后启动报表服务器,在浏览器中输入下地址:http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.NewDateDemo,如下图所示: