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":数据存放路径,记得路径要真实存在啊,否则会报错。
总结:不爽的地方,翻页的时候感觉有点慢,难免的,到磁盘上读一次再加载到内存,肯定慢了。