金蝶EAS,扩展报表,Java数据集代码示例

业务场景:业务相对复杂时,无法直接通过SQL直接查询出相应的数据集。可以使用Java数据集实现。

Java数据集可以针对查询结果进行相应的加工,向前端扩展报表提供符合要求的结果集。

 

package com.kingdee.eas.custom.si.rpt;

import java.util.Map;
import java.awt.Window;
import com.kingdee.jdbc.rowset.IRowSet;
import com.kingdee.eas.custom.si.util.DaoUtil;
import com.kingdee.eas.custom.si.util.VerifyUtil;
import com.kingdee.eas.rpts.ctrlsqldesign.param.AbstractJavaDataSet;

/**
 * 演示报表Java数据集,用于扩展报表
 * @author 郭旭
 *
 */
public class DemoDataSet extends AbstractJavaDataSet {
	
	/**报表过滤参数**/
	private Map<?, ?> filters;

	/**
	 * 返回数据集
	 */
	@Override
	public IRowSet[] getCustomRowSet(Window parent, String otherDataCenter) throws Exception {
		
		// 存放数据集
		IRowSet[] ds = new IRowSet[1];
		String number = (String) this.filters.get("number"); //过滤参数
		
		StringBuffer sql = new StringBuffer();
		sql.append("select FNumber 登录名, FName_L2 用户实名 from T_PM_User where 1 = 1").append("\n");
		if(VerifyUtil.notNull(number)){
			System.out.println("过滤参数:number = " + number);
			sql.append("and FNumber = '" + number + "'").append("\n");
		}
		IRowSet rs = DaoUtil.executeQuery(sql);
		ds[0] = rs;
		
		return ds;
			
	}

	/**
	 * 如需返回查询语句时,实现该方法
	 */
	@Override
	public String getCustomSQL(Window parent) throws Exception {
		return super.getCustomSQL(parent);
	}
	
	/**
	 * 报表过滤参数
	 */
	@SuppressWarnings("unchecked")
	@Override
	public void setFilterParam(Map filterParamMap) {
		filters = filterParamMap;
	}

}

 

 

 

 

 

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值