iBatis中RowHandler处理大数据量的导出



ibatisRowHandler 大数据量导出

背景:一次性导出几十万条数据到excel,此时的导出效率会严重损失。

解决方法:用ibatis中的RowHandler,一次只处理一条数据,内存中只保持一条数据,导出时每5万条创建一个sheet

具体实现方法:

MyRowHandler处理类:

Java代码

 

  1. import java.util.Map;  
  1.   
  1. import org.apache.poi.hssf.usermodel.HSSFCell;  
  1. import org.apache.poi.hssf.usermodel.HSSFRichTextString;  
  1. import org.apache.poi.hssf.usermodel.HSSFRow;  
  2. import org.apache.poi.hssf.usermodel.HSSFSheet;  
  1. import org.apache.poi.hssf.usermodel.HSSFWorkbook;  
  1.   
  1. import com.ibatis.sqlmap.client.event.RowHandler;  
  1.   
  1. public class MyRowHandler implements RowHandler {  
  2.     HSSFWorkbook wb;  
  1.     HSSFSheet sheet ;   
  1.     HSSFRow row;  
  1.     HSSFCell cell;  
  1.     int dataNum=0;  
  1.     int rowStart = 1;  
  1.     @Override  
  1.     public void handleRow(Object arg0){  
  1.         dataNum++;  
  1.         if(dataNum%50000==0){  
  1.             //5万条记录分页  
  1.             setSheet();  
  1.         }  
  1.           
  1.         Map map = (Map)arg0;  
  1.         //在这里处理逻辑,插入数据到excel  
  1.         System.out.println(map.get("key"));  
  1.         System.out.println(map.get("value"));  
  1.           
  1.     }  
  1.     public HSSFWorkbook getWb() {  
  1.         return wb;  
  1.     }  
  1.     public void setWb(HSSFWorkbook wb) {  
  1.         this.wb = wb;  
  1.         setSheet();  
  1.     }  
  1.     public void setSheet(){  
  1.         this.sheet= wb.createSheet();  
  1.         rowStart = 1;  
  1.         //写表头  
  2.         writeHeader();  
  3.     }  
  4.     public void writeHeader(){  
  5.         String[] header = {"ID","类型"};  
  6.         row = sheet.createRow(0);  
  7.         int n=0;  
  8.         for (String  head : header) {  
  9.             cell = row.createCell((short) n);  
  1.             HSSFRichTextString str = new HSSFRichTextString(head);  
  1.             cell.setCellValue(str);  
  1.             n++;   
  2.         }  
  1.     }  
  1.       
  1. }  

 

 action中执行:

Java代码

 

  1. public String execute(){  
  1.           
  1.         String fileName="F:\\05-JAVA\\测试.xls";  
  1.         HSSFWorkbook wb = new HSSFWorkbook();  
  2.         MyRowHandler handler = new MyRowHandler();  
  1.         handler.setWb(wb);  
  1.         DaoFactory.getIbatisDao().getSqlMapClientTemplate().queryWithRowHandler("term.base", handler);  
  2.         wb = handler.getWb();  
  3.           
  1.         OutputStream os = null;  
  1.         try {  
  1.             os = new FileOutputStream(fileName);  
  1.             wb.write(os);  
  1.         }catch(Exception e){  
  1.               
  1.         }finally{  
  1.             try {  
  1.                 os.close();  
  2.             } catch (IOException e) {  
  3.                 e.printStackTrace();  
  4.             }   
  5.         }  
  6.              return "success";  
  1.     }  

 

源文档 <http://sdkd-tiger.iteye.com/blog/1469063>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值