Excel大数据量导出

  • 问题

在进行导出Excel的时候,由于数据量十分大,导致流不能很快的写入到Excel文件,使得流一直在内存中,导致内存占用4个多G,严重影响服务状态。

  • 方案

找到问题点是因为流或者Excel的数据结构(如XSSFWorkbook等)在内存停留时间太长。所以要么快速处理数据,要么就是将存储位置改变。

  • 结果

最后我们发现其实Excel已经提供了SXSSFWorkbook。他和XSSFWorkbook的优化点就在于他会将多余的数据存储在硬盘。

SXSSFWorkbook wb = new SXSSFWorkbook();

当实例化SXSSFWorkbook的时候,默认是当数据量大于100的时候,多余的数据将不会存储在内存中,他会存储到硬盘中。

  • 最后

果然,JVM内存果然就占用比较少,同时处理速度和使用XSSFWorkbook的时候简直就是天和地!

猜你喜欢

转载自my.oschina.net/u/3095034/blog/2961941