亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java使用POI導(dǎo)出大數(shù)據(jù)量Excel的方法

 更新時間:2019年11月22日 09:52:59   作者:小小小LIN子  
今天需要寫一個導(dǎo)出的Excel的功能,但是發(fā)現(xiàn)當(dāng)數(shù)據(jù)量到3萬條時,列數(shù)在23列時,內(nèi)存溢出,CPU使用100%,測試環(huán)境直接炸掉。小編給大家分享基于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)載,煩請注明出處,謝謝!

相關(guān)文章

  • iOS socket網(wǎng)絡(luò)編程實例詳解

    iOS socket網(wǎng)絡(luò)編程實例詳解

    socket是一個針對TCP和UDP編程的接口,你可以借助它建立TCP連接等。這篇文章主要介紹了iOS socket網(wǎng)絡(luò)編程 ,需要的朋友可以參考下
    2017-03-03
  • 詳談Java靜態(tài)動態(tài)的問題

    詳談Java靜態(tài)動態(tài)的問題

    下面小編就為大家?guī)硪黄斦凧ava靜態(tài)動態(tài)的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Java中synchronized的優(yōu)化措施

    Java中synchronized的優(yōu)化措施

    這篇文章主要介紹了Java中synchronized的優(yōu)化,介紹為了實現(xiàn)高效并發(fā),虛擬機對synchronized 做的一系列的鎖優(yōu)化措施,本文給大家介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • Java for-each循環(huán)使用難題2例(高級使用方法)

    Java for-each循環(huán)使用難題2例(高級使用方法)

    從Java5起,在Java中有了for-each循環(huán),可以用來循環(huán)遍歷collection和array。For each循環(huán)允許你在無需保持傳統(tǒng)for循環(huán)中的索引,或在使用iterator /ListIterator時無需調(diào)用while循環(huán)中的hasNext()方法就能遍歷collection
    2014-04-04
  • java swing實現(xiàn)簡單計算器界面

    java swing實現(xiàn)簡單計算器界面

    這篇文章主要為大家詳細介紹了java swing實現(xiàn)簡單計算器界面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Jmeter測試時遇到的各種亂碼問題及解決

    Jmeter測試時遇到的各種亂碼問題及解決

    這篇文章主要介紹了Jmeter測試時遇到的各種亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Java Scanner 類的使用小結(jié)

    Java Scanner 類的使用小結(jié)

    在筆試編程過程中,關(guān)于數(shù)據(jù)的讀取如果迷迷糊糊,那后來的編程即使想法很對,實現(xiàn)很好,也是徒勞,于是在這里認真總結(jié)了Java Scanner 類的使用,需要的朋友可以參考下
    2018-10-10
  • java開發(fā)validate方法中校驗工具類詳解

    java開發(fā)validate方法中校驗工具類詳解

    這篇文章主要為大家介紹了java開發(fā)validate方法中校驗工具類詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • java開發(fā)技巧代碼寫的快且bug少的原因分析

    java開發(fā)技巧代碼寫的快且bug少的原因分析

    這篇文章主要為大家介紹了java開發(fā)中代碼寫的快且bug少的原因分析及技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • Java NIO框架Netty簡單使用的示例

    Java NIO框架Netty簡單使用的示例

    本篇文章主要介紹了Java NIO框架Netty簡單使用的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12

最新評論