动态修改数据

编辑
  • 文档创建者:印然
  • 浏览次数:13850次
  • 编辑次数:12次
  • 最近更新:Carly 于 2019-09-11
  • 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,如下图所示:



    附件列表


    主题: 二次开发
    标签: 暂无标签 编辑/添加标签
    如果您认为本文档还有待完善,请编辑

    文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
    关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
    若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

    此页面有帮助吗?只是浏览 [ 去社区提问 ]