报表导出解决方案,包括延时导出和即时导出

/**
* 根据sql,csv标题,csv内容,csv名称,报表名称,报表编号,报表压缩文件夹名称,返回报表地址(本地导出、延迟导出)
*
* @param sql
* 需导出、统计SQL
* @param csvTitle
* csv文档中标题
* @param classProperty
* csv文档中标题
* @param rpt_nm
* 报表名称
* @param rpt_cd
* 报表编号
* @param args
* Class
* @return String
*/
public String exprotCvs(String sql, String csvTitle, String classProperty,
String rpt_nm, String rpt_cd, Class args) {
String filePath = "";
int iTotalCount = baseDao.getResultCount(sql);
if (iTotalCount >= iBatchSize) { // 导出条数大于需批量导出条数时,记录该SQL,转为延迟处理
UserRpt userRpt = new UserRpt();
long id = SequenceManager.getKey(UserRpt.SEQUENCE); // 报表ID
userRpt.setId(id);
userRpt.setUser_cd("test"); // test
userRpt.setStatus("0"); // 运行状态-"0未运行"
userRpt.setRpt_nm(rpt_nm); // 报表名称
userRpt.setRpt_cd(rpt_cd); // 报表编号
userRpt.setCrt_dt(AQPDateUtil.generateTime()); // 创建时间
userRpt.setRpt_desc("记录数:" + String.valueOf(iTotalCount)); // 备注描述
baseDao.insertRpt(userRpt); // 新增一条用户报表信息
insertRptSql(sql, id); // 新增若干条用户报表SQL信息
return "@" + id;
}
List totalResult = baseDao.queryAllBySql(sql, args);
if (iTotalCount <= iPageSize) { // 导出条数小于CSV最大条数时,导出单个CSV
filePath = getCsvPath(totalResult, csvTitle, classProperty, rpt_cd);
return filePath;
}
List result = AQPUtil.getListResult(totalResult, iPageSize); // 根据单个CSV最大条数,将总结果集拆分为若干个封装在List中
String[] sFilePath = new String[result.size()];
for (int i = 0; i < result.size(); i++) {
sFilePath[i] = this.getCsvPath((List) result.get(i), csvTitle,
classProperty, rpt_cd);
}
filePath = FilePathUtil.zipFiles(sFilePath, AQPDateUtil.generateTime()
+ "_" + rpt_cd + ".zip");
return filePath;
}

/**
* 根据sql,csv标题,csv内容,csv名称,报表编号,报表压缩文件夹名称,返回报表地址(联机导出)
*
* @param sql
* 需导出、统计SQL
* @param csvTitle
* csv文档中标题
* @param classProperty
* csv文档中标题
* @param rpt_cd
* 报表编号
* @param args
* Class
* @return String
*/
public String exprotTP(String sql, String csvTitle, String classProperty,
String rpt_cd, Class args) {
String filePath = "";
List result = null;
int iTotalCount = baseDao.getResultCount(sql);
int iCsvSize = iTotalCount / iPageSize;
if (iTotalCount % iPageSize > 0) {// 如果不能取整,则总页数加一
iCsvSize++;
}
String[] sFilePath = new String[iCsvSize];
for (int i = 0; i < iCsvSize; i++) {
result = new ArrayList();
String pageSql = baseDao.getQueryPageSql(sql, i + 1, iPageSize);
result = baseDao.queryAllBySql(pageSql, args);
sFilePath[i] = this.getCsvPath(result, csvTitle, classProperty,
rpt_cd);
}
filePath = FilePathUtil.zipFiles(sFilePath, AQPDateUtil.generateTime()
+ "_" + rpt_cd + ".zip");
return filePath;
}

/**
* 根据List结果集,csv标题,csv内容,csv名称,返回导出csv本地路径
*
* @param result
* 查询出List列表
* @param csvTitle
* csv文档中标题
* @param classProperty
* csv标题内容
* @param csvCode
* 导出csv名称
* @return String 导出csv本地路径
*/
public String getCsvPath(List result, String csvTitle,
String classProperty, String csvCode) {
FileObject fileObject = FilePathUtil.getFileObject(csvCode + ".csv");
try {
fileObject.writeLine(csvTitle);
CsvLineUtil csvLine = new CsvLineUtil();
Object obj = null;
Collection<String> collection = AQPUtil
.getCollectionPeroperty(classProperty);
if (collection.size() != csvTitle.split(",").length) {
throw new DpcaRuntimeException("", "CSV中标题及内容长度不一致!");
}
int idx = 1;
for (int i = 0; i < result.size(); i++) {
obj = new Object();
obj = (Object) result.get(i);
csvLine.initFieldsData(collection.size());
String strProperty = null;
for (Iterator<String> iter = collection.iterator(); iter
.hasNext();) {
strProperty = iter.next();
csvLine.setFieldData(idx, (String) AQPUtil
.getObjectProperty(obj, strProperty));
idx++;
if (idx - 1 == collection.size()) {
fileObject.writeLine(csvLine.getData());
idx = 1;
}
}
}
} catch (Exception e) {
e.printStackTrace();
throw new DpcaRuntimeException("", e.getMessage());
} finally {
fileObject.close();
}
return fileObject.getAbsolutepath();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值