1.业务场景
帆软报表,有些复杂得数据需要使用到下面的程序(java代码)获得数据集,来实现复杂的数据展示(不能通过sql语句展示出来的业务数据),本人是图片问题
2 官方文档
这里不得不吐槽一下帆软官方文档上的demo过于简单;
数据获得
example/SimpleParamTableDataDemo.java at release/10.0 - example - 帆软第三方插件仓库
列名获得
example/SimpleArrayTableDataDemo.java at release/10.0 - example - 帆软第三方插件仓库
按照官方demo就这样写死的, 要是表结构改变(增加字段),就需要每次手动去在这个String[]增加之后,在打包部署,非常麻烦
3.咨询客服,也是仅供参考,具体自己写逻辑,不提供业务技术支持
7月份最初版就是写死的,10月份在不忙的时候自己研究,(一个月的成果啊~,改的至少40次,都快吐槽.因为每次打包部署), 多的不说直接上代码
/** 可以自己拿过去使用 有注解应该能看懂,,多多点赞支持分享 */
public class ryyV8Demo15Day02 extends SimpleTableData {
Connection con = null;
//定义的是类的成员变量;初始化方式不对 ,就会报错;
// private ArrayList<Object[]> valueList = null; //方式一
// private ArrayList<Object[]> valueList ; //方式二
//定义的是类的成员变量;初始化一定要new (可以不使用)
private ArrayList<Object[]> valueList = new ArrayList<>();
private static String[] nameList = null;
private static String id ;
/** 本地main方法测试 打开*/
// public static void main(String[] args) {
//
// ryyV8Demo15Day02 demo15Day02 = new ryyV8Demo15Day02();
// List<Object[]> list = demo15Day02.loadData();
// for (int i = 0; i < demo15Day02.nameList.length; i++) {
System.out.println(nameList[i]);
// System.out.println(nameList[i] +": "+list.get(0)[i]);
// }
// }
/**
* 获取列名(动态)
* @param
* @return
* @version 3.0
* @date 2023/10/15
*/
public final void getColumnNames (){
FineLoggerFactory.getLogger().info("nameList开始");
System.out.println("nameList开始");
if (nameList != null){
System.out.println("nameList已经初始化有值");
return;
}
System.out.println("提示nameList空值");
//这里我固定写死参数 000
String sql = "SELECT * FROM 数据库表名 A WHERE (1=1) and ID = '000'";// + tableName;
FineLoggerFactory.getLogger().info("Query SQL of ParamTableDataDemo: \n" + sql);
// 下面开始建立数据库连接,按照刚才的SQL语句进行查询
// 根据连接名获取FR数据连接定义的数据连接,如果没有定义,也可以参考getConnection方法自己创建连接
// 用String[]保存 k 初始化
// String[] ColumnNames = null;
try {
con = getConnection();
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(sql);
// 获得记录的详细信息,然后获得总列数
ResultSetMetaData rsmd = rs.getMetaData();
System.out.println("获得记录的详细信息");
// System.out.println(rs.next());
int colNum = rsmd.getColumnCount();
FineLoggerFactory.getLogger().info("rsmd.getColumnCount():k的数量:" + colNum);
// rs.next();
// 列名 赋值 String[]
nameList = new String[colNum];
for (int i = 0; i < colNum; i++) {
nameList[i] = rsmd.getColumnName(i + 1);
}
// 释放数据库资源
rs.close();
stmt.close();
} catch (Exception e) {
FineLoggerFactory.getLogger().error(e.getMessage(), e);
}
System.out.println("初始化类加载的时候运行--获取列名方法(getColumnNames)结束-------"+nameList.length);
}
/**
* 程序集的列名(K)
*
* @param
* @return
* @version 2.0
* @date 2023/9/18
*/
@Override
public String[] initColumnNames() {
FineLoggerFactory.getLogger().info("demo02-开始--列名15ryy");
getColumnNames();
return nameList;
}
@Override
public List<Object[]> loadData() {
id = ((ParameterProvider) (parameters.get().toArray())[0]).getValue().toString();
//测试使用 打开
// id = "08b2e6cbcf1e429baf30fff6fab7ccf2";
FineLoggerFactory.getLogger().info("loadData开始--首先查看参数"+id);
//获取图片 自己的业务代码
HashMap<String, Object> mp = getPicInfo(id);
List<Object[]> list = assembleData(mp, id);
try {
if (con != null) {
con.close();
}
} catch (SQLException e) {
FineLoggerFactory.getLogger().error(e.getMessage(), e);
}
return list;
}
/**
* 获取数据库连接 driverName和 url 可以换成您需要的
*
* @return Connection
*/
private Connection getConnection() throws Exception {
com.fr.data.impl.Connection conn = ConnectionConfig.getInstance().getConnection("帆软编辑器自自己绑定的数据库命名"); //参考上面官方文档
con = conn.createConnection();
//本地连接测试打开
// String driverName = "oracle.jdbc.driver.OracleDriver";
String url = "自己写"; //测试
// String username = "111";
// String password = "123456";
// Connection con = null;
// try {
// Class.forName(driverName);
// con = DriverManager.getConnection(url, username, password);
// } catch (Exception e) {
// FineLoggerFactory.getLogger().error(e.getMessage(), e);
// }
return con;
}
}