请上传宽度大于 1200px,高度大于 164px 的封面图片
    调整图片尺寸与位置
    滚轮可以放大缩小图片尺寸,按住图片拖动可调整位置,多余的会自动被裁剪掉
取消
夏堇流年(uid:76526)
职业资格认证:FCA-FineReport | FCA-FineBI
  • 设置了全局参数:limit_day、limit_month、limit_year、limit_user、limit_node预览报表时可以获取到参数值,表单预览时为啥就变成了公式下面是报表预览的:
  • package com.fr.data;import com.fr.base.FRContext;import com.fr.file.DatasourceManager;import com.fr.stable.ParameterProvider;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.ResultSetMetaData;import java.sql.Statement;import java.util.ArrayList;/** * 带参数的程序数据集Demo * * @author fanruan */public class ParamTableDataDemo extends AbstractTableData {    /**     * 列名数组,保存程序数据集所有列名     */    private String columnNames;    /**     * 定义程序数据集的列数量     */    private int columnNum = 10;    /**     * 保存查询表的实际列数量     */    private int colNum = 0;    /**     * 保存查询得到列值     */    private ArrayList valueList = null;    /**     * 构造函数,定义表结构,该表有10个数据列,列名为column#0,column#1,。。。。。。column#9     */    public ParamTableDataDemo() {        columnNames = new String;        for (int i = 0; i < columnNum; i++) {            columnNames = "column#" + String.valueOf(i);        }    }    /**     * 实现其他四个方法     *     * @return columnNum     */    @Override    public int getColumnCount() {        return columnNum;    }    @Override    public String getColumnName(int columnIndex) {        return columnNames;    }    @Override    public int getRowCount() {        init();        return valueList.size();    }    @Override    public Object getValueAt(int rowIndex, int columnIndex) {        init();        if (columnIndex >= colNum) {            return null;        }        return ((Object) valueList.get(rowIndex));    }    /**     * 准备数据     */    private void init() {        // 确保只被执行一次        if (valueList != null) {            return;        }        // 保存得到的数据库表名        String tableName = ((ParameterProvider) (parameters.get().toArray())).getValue().toString();        // 构造SQL语句,并打印出来        String sql = "select * from " + tableName;        FRContext.getLogger().info("Query SQL of ParamTableDataDemo: \n" + sql);        // 保存得到的结果集        valueList = new ArrayList();        // 下面开始建立数据库连接,按照刚才的SQL语句进行查询        com.fr.data.impl.Connection conn = DatasourceManager.getInstance().getConnection("prod");        try {            Connection con = conn.createConnection();            Statement stmt = con.createStatement();            ResultSet rs = stmt.executeQuery(sql);            // 获得记录的详细信息,然后获得总列数            ResultSetMetaData rsmd = rs.getMetaData();            colNum = rsmd.getColumnCount();            // 用对象保存数据            Object objArray = null;            while (rs.next()) {                objArray = new Object;                for (int i = 0; i < colNum; i++) {                    objArray = rs.getObject(i + 1);                }                // 在valueList中加入这一行数据                valueList.add(objArray);            }            // 释放数据库资源            rs.close();            stmt.close();            con.close();            // 打印一共取到的数据行数量        } catch (Exception e) {            e.printStackTrace();        }    }    /**     * 获取数据库连接 driverName和 url 可以换成您需要的     *     * @return Connection     */    public Connection getConnection() {        String driverName = "oracle.jdbc.driver.OracleDriver";        String url = "jdbc:oracle:thin:@***.***.***.***:1521:prod";        String username = "***";        String password = "***";        Connection con;        try {            Class.forName(driverName);            con = DriverManager.getConnection(url, username, password);        } catch (Exception e) {            e.printStackTrace();            return null;        }        return con;    }    /**     * 释放一些资源,因为可能会有重复调用,所以需释放valueList,将上次查询的结果释放掉     *     * @throws Exception e     */    @Override    public void release() throws Exception {        super.release();        this.valueList = null;    }}预览时无数据,日志只有那几个,就打印出了需要执行的sql,是哪里写的有问题吗照着帮助文档里的带参数的简单数据集那个的class文件修改的
  • JS事件提示:Cannot read property 'points' of undefined,是缺少了什么文件吗?完整JS如下:var vanchart = FR.Chart.WebUtils.getChart('A2').vanCharts.charts,  openAutoTooltipCarouselDelay = 2000;  openAutoTooltipCarousel();    function openAutoTooltipCarousel(ele){  var series = vanchart.series; var points = series.points,   pointsLen = points.length;  var pointIndex = 0;    window.openAutoTooltipCarouselTimer = setInterval(function (){  vanchart.showTooltip(points);    pointIndex < pointsLen - 1 ? pointIndex++ : pointIndex = 0;    }, openAutoTooltipCarouselDelay)  }  
  • 页面初始化后,运营部有值时,对应的下拉树控件能自动选中子节点

5

126

5

10

没有更多
个人成就
内容被浏览1,941
加入社区7年339天
返回顶部