Java使用POI導(dǎo)出大數(shù)據(jù)量Excel的方法
今天需要寫一個導(dǎo)出的Excel的功能,但是發(fā)現(xiàn)當(dāng)數(shù)據(jù)量到3萬條時,列數(shù)在23列時,內(nèi)存溢出,CPU使用100%,測試環(huán)境直接炸掉。在本地測試時發(fā)現(xiàn),導(dǎo)出3000條左右的數(shù)據(jù)的時候,堆內(nèi)存瞬間升高500M左右。然后發(fā)現(xiàn)了 SXSSFWorkbook 這個類。
簡介
SXSSFWorkbook 需要 poi-ooxml 包 3.8 及以上開始支持,我這邊適使用的是 3.9 版本,本質(zhì)是一個 XSSFWorkbook 類( Excel2007 ),它使用的方式是采用 硬盤空間 來大幅降低 堆內(nèi)存 的占用,在系統(tǒng)的臨時文件夾目錄創(chuàng)建一個臨時文件,然后將所有大于約定行數(shù)的數(shù)據(jù)都存入臨時文件,而不是全部放在內(nèi)存中,內(nèi)存中只存放 最新的 的約定條數(shù)的數(shù)據(jù),從而實現(xiàn)以硬盤空間換取內(nèi)存空間,避免內(nèi)存溢出
使用方式
與正常的Excel導(dǎo)出方法沒有區(qū)別,只是將實例化的類換為 SXSSFWorkbook
SXSSFWorkbook workbook = null;
OutputStream outputStream = null;
try {
outputStream = response.getOutputStream();
//創(chuàng)建工作簿
workbook = new SXSSFWorkbook();
// 打開壓縮功能 防止占用過多磁盤
workbook.setCompressTempFiles(true);
// 創(chuàng)建一個工作表
Sheet sheet = workbook.createSheet("表名");
// 創(chuàng)建一行
Row titleRow = sheet.createRow(0);
// 創(chuàng)建一個單元格
Cell cell = titleRow.createCell(0);
// 給單元格賦值
cell.setCellValue("內(nèi)容");
// 將工作簿寫入輸出流
workbook.write(outputStream);
} catch (Exception e) {
e.printStackTrace();
}finally {
if (workbook != null) {
//使用完畢后將產(chǎn)生的臨時文件刪除 防止將磁盤搞滿
workbook.dispose();
}
if (outputStream != null) {
outputStream.close();
}
}
總結(jié)
以上所述是小編給大家介紹的Java使用POI導(dǎo)出大數(shù)據(jù)量Excel的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
- Java利用POI實現(xiàn)導(dǎo)入導(dǎo)出Excel表格示例代碼
- java poi導(dǎo)出圖片到excel示例代碼
- Java使用POI實現(xiàn)導(dǎo)出Excel的方法詳解
- Java使用poi組件導(dǎo)出Excel格式數(shù)據(jù)
- Java中利用POI優(yōu)雅的導(dǎo)出Excel文件詳解
- Java Web使用POI導(dǎo)出Excel的方法詳解
- Java中用POI實現(xiàn)將數(shù)據(jù)導(dǎo)出到Excel
- java poi導(dǎo)出excel時如何設(shè)置手動換行
- Java使用Poi導(dǎo)出Excel表格方法實例
相關(guān)文章
Spring+Mybatis 實現(xiàn)aop數(shù)據(jù)庫讀寫分離與多數(shù)據(jù)庫源配置操作
這篇文章主要介紹了Spring+Mybatis 實現(xiàn)aop數(shù)據(jù)庫讀寫分離與多數(shù)據(jù)庫源配置操作,需要的朋友可以參考下2017-09-09
Java數(shù)據(jù)結(jié)構(gòu)徹底理解關(guān)于KMP算法
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)關(guān)于KMP算法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
Java中的Map集合根據(jù)key值排序的實現(xiàn)
本文主要介紹了Java中的Map集合如何根據(jù)key值排序,包含使用TreeMap和使用lambda表達(dá)式和Stream流兩種方法,具有一定的參考價值,感興趣的可以了解一下2024-03-03
Gson中@JsonAdater注解的幾種方式總結(jié)
這篇文章主要介紹了Gson中@JsonAdater注解的幾種方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08
mybatis使用pageHelper插件進(jìn)行查詢分頁
這篇文章主要介紹了mybatis使用pageHelper插件進(jìn)行查詢分頁,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
SpringCloud網(wǎng)關(guān)Gateway架構(gòu)解析
這篇文章主要介紹了SpringCloud網(wǎng)關(guān)Gateway架構(gòu)解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03

