反馈已提交

网络繁忙

从数据库读取报表

  • 文档创建者:文档助手1
  • 历史版本:25
  • 最近更新:RosieY 于 2023-03-14
  • 1. 概述

    1.1 应用场景

    注:阅读本文时,请先阅读 保存模板至数据库 。

    保存模板至数据库 中,可以将 cpt 模板保存入库,例如示例中将 GettingStarted.cpt 存在数据库表 report 中,那保存在数据库中的模板要如何访问呢?

    保存在数据库中的模板不再通过存为模板点击预览访问,而是自定义 Java 类将其转换为网络报表,在 Web 浏览器中进行访问。如通过本文示例的方法转换后,在浏览器中输入:

    http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.ReadFromDatabase&cptname=GettingStarted.cpt

    就可以直接在浏览器端访问模板。

    1.2 实现原理

    通过程序从数据库读取报表后将其转换成程序网络报表。

    2. 示例

    以下示例将从数据库中读取 保存模板至数据库 中保存的 GettingStarted.cpt 模板,然后将其转换成程序网络报表。

    2.1 准备编译环境

    编译程序前,需先创建一个 Java 工程环境,并且需要一个 Java 编辑器,如 Eclipse 或 idea 。

    在编辑器工程中导入 FineReport 工程 JAR 包。包括用户自己报表工程

    %FR_HOME%/lib下的所有的包,

    %FR_HOME%/server/lib 下的所有包,

    %FR_HOME%/webapps/webroot/WEB-INF/lib下的所有包;

    代码中会将模板信息入库,还需要导入对应的 JDBC 驱动,

    还要引入 JDK 下的 tools.jar。详细操作可参考:编译Java程序 

    2.2 定义程序网络报表

    2.2.1 编写 Java 程序

    在编辑器中编写 Java 程序 ReadFromDatabase.Java,继承 com.fr.web.Reportlet 抽象类,并实现 public Report createReport(ReportletRequest reportletRequest) 方法。读取数据库中存储的 GettingStarted.cpt 模板后将其转换成程序网络报表。完整代码可参见:

    cpt 模板代码:

    https://code.fanruan.com/demo/example/src/branch/release/10.0/src/main/java/com/fr/demo/ReadFromDatabase.java

    frm 模板代码:

    注:ReadfrmFromDatabase.java 文件不支持设置了参数控件联动的模板,模板预览时,点击控件查询不能正常预览。

    package com.fr.plugin.wysiwyg.theme;

    import com.fr.data.core.db.DBUtils;
    import com.fr.form.main.DashboardTemplate;
    import com.fr.form.main.Form;
    import com.fr.log.FineLoggerFactory;
    import com.fr.web.session.SessionLocalManager;
    import com.fr.web.weblet.DBFormlet;
    import javax.servlet.http.HttpServletRequest;
    import java.io.InputStream;
    import java.sql.Blob;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.Map;
    public class NewReadFrmFromDatabase extends DBFormlet {

        @Override
        protected DashboardTemplate createDashboard(HttpServletRequest req) throws Exception {
            String name = req.getParameter("reportname");
            return createForm(name);
        }

        @Override
        public Form createForm(String reportName) {
            Form form = new Form();
            Connection connection = null;
            try {
                connection = getConnection();
                // 从数据库中读模板
                String sql = "select frm from report where frmname = '" + reportName
                        + "'";
                Statement smt = connection.createStatement();
                ResultSet rs = smt.executeQuery(sql);
                while (rs.next()) {
                    Blob blob = rs.getBlob(1);
                    FineLoggerFactory.getLogger().info(blob.toString());
                    InputStream ins = blob.getBinaryStream();
                    form.readStream(ins);
                    return form;
                }
            } catch (Exception e) {
                throw SessionLocalManager.createLogPackedException(e);
            }finally {
                DBUtils.closeConnection(connection);
            }
            return form;
        }
        private static Connection getConnection() throws ClassNotFoundException, SQLException {
            // 定义数据连接(根据你实际数据库信息进行修改)
            String driver = "com.mysql.jdbc.Driver";
            String url = "jdbc:mysql://localhost:3306/test";
            String user = "root";
            String pass = "123456";
            Class.forName(driver);
            Connection conn = DriverManager.getConnection(url, user, pass);
            return conn;
        }
        @Override
        public void setParameterMap(Map<String, Object> arg0) {
            // TODO Auto-generated method stub
        }


    }

    2.2.2 编译 Java 文件

    Java 程序编写完成后,在编译器中编译 ReadFromDatabase.java ,编译通过后,将会在编译器对应工程文件存储路径下生成 ReadFromDatabase.class 类文件。如下图所示:

    2.3 发布并在 Web 端预览 

    将编译后的 ReadFromDatabase.class 放到报表工程 %FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\demo目录下。如下图所示:


    启动服务器,在浏览器中输入访问报表工程文件的路径,如使用本地设计器工程,启动后在浏览器端输入

    注:URL 路径中 cptname 将传递模板名称到类文件,必须和类文件中的参数名称一致。

    http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.NewDateDemo便可以预览报表。如下图所示:

    222

    决策报表浏览器端入

    http://localhost:8075/webroot/decision/view/form?viewlet=com.fr.demo.ReadfrmFromDatabase&reportname=Form5.frm即可看到到报表预览效果。如下图所示:

    3.png

    附件列表


    主题: 二次开发
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持