Excel大数据量导出

  • 问题

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

  • 方案

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

  • 结果

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

SXSSFWorkbook wb = new SXSSFWorkbook();

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

  • 最后

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

  • 总结

当碰到问题的时候,应该多测试代码,debug将问题定位到最细的点。当点位到最细的点的时候才能更好地对有问题的点加入更合适的方案!

转载于:https://my.oschina.net/u/3095034/blog/2961941

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值