| package com.panzhihua.common.listen; | 
|   | 
| import com.alibaba.excel.context.AnalysisContext; | 
| import com.alibaba.excel.event.AnalysisEventListener; | 
| import com.alibaba.fastjson.JSONObject; | 
| import com.panzhihua.common.exceptions.ServiceException; | 
| import com.panzhihua.common.model.dtos.civil.ComActSocialWorkerExcelVO; | 
| import com.panzhihua.common.model.vos.R; | 
| import com.panzhihua.common.model.vos.community.ComCvtServeExcelVO; | 
| import com.panzhihua.common.service.community.CommunityService; | 
| import lombok.extern.slf4j.Slf4j; | 
|   | 
| import java.util.ArrayList; | 
| import java.util.List; | 
|   | 
| /** | 
|  * @description: 便民服务导入监听 | 
|  * @author: Null | 
|  * @date: 2021/3/11 13:26 | 
|  */ | 
| @Slf4j | 
| public class ComActSocialWorkerExcelListen extends AnalysisEventListener<ComActSocialWorkerExcelVO> { | 
|   | 
|     private CommunityService communityService; | 
|   | 
|     private Long communityId; | 
|   | 
|     public ComActSocialWorkerExcelListen(CommunityService communityService, Long communityId) { | 
|         this.communityService = communityService; | 
|         this.communityId = communityId; | 
|     } | 
|   | 
|   | 
|     private static final int BATCH_COUNT = 5000; | 
|     private List<ComActSocialWorkerExcelVO> list = new ArrayList<>(); | 
|   | 
|     @Override | 
|     public void invoke(ComActSocialWorkerExcelVO comActSocialWorkerExcelVO, AnalysisContext analysisContext) { | 
|         list.add(comActSocialWorkerExcelVO); | 
|         // 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOM | 
|         if (list.size() >= BATCH_COUNT) { | 
|             log.info("excel导入数据【{}】", JSONObject.toJSONString(list)); | 
|             R r = this.communityService.listSaveSocialWorkerExcelVO(list, this.communityId); | 
|             if (!R.isOk(r)) { | 
|                 throw new ServiceException(r.getMsg()); | 
|             } | 
|             //清空list | 
|             list.clear(); | 
|         } | 
|   | 
|     } | 
|   | 
|     @Override | 
|     public void doAfterAllAnalysed(AnalysisContext analysisContext) { | 
|         log.info("excel导入数据【{}】", JSONObject.toJSONString(list)); | 
|         R r = this.communityService.listSaveSocialWorkerExcelVO(list, this.communityId);//确保最后遗留的数据保存在数据库中 | 
|         if (!R.isOk(r)) { | 
|             throw new ServiceException(r.getMsg()); | 
|         } | 
|     } | 
| } |