jasperReport通过SQL加载数据是一次把所有的数据都加载到了内存中,如果内存大小不够,怎么办呢?应该把获得的数据一部分保存在内存中,另一部分写到指定路径的硬盘上去。代码很简单,如下:
1 JRFileVirtualizer virtualizer = new JRFileVirtualizer(2, reportFile.getParentFile() + "/cacheDir");
2 parameters.put(JRParameter.REPORT_VIRTUALIZER, virtualizer);
3 jasperPrint =
JasperFillManager.fillReport(
jasperReport,
parameters,
DBConnection.getInstance()
);
这样就可以了,第1行的两个参数的意思是:
2: 内存中存放两页数据
reportFile.getParentFile() + "/cacheDir":数据存放路径,记得路径要真实存在啊,否则会报错。
总结:不爽的地方,翻页的时候感觉有点慢,难免的,到磁盘上读一次再加载到内存,肯定慢了。
本文介绍了一种在使用JasperReport进行报表生成时避免内存溢出的方法。通过设置JRFileVirtualizer参数,可以将部分数据缓存到硬盘,从而减少内存占用。此方案适用于处理大量数据的情况。
1189

被折叠的 条评论
为什么被折叠?



