前端組件
<hd-flex> <el-dialog v-model="isUploadDialog" width="50%" lock-scroll=false> <el-upload class="upload-demo" drag :action="url" :on-success="success" :on-error="error" :headers="uploadHeaders" :limit="1" :on-exceed="handleExceed" :file-list="fileList" accept=".xlsx,.xls"> <i class="el-icon-upload"></i> <div class="el-upload__text"><em>點擊上傳</em></div> <div class="el-upload__tip" slot="tip">只能上傳xlsx/xls檔案,且不超過500kb</div> </el-upload> </el-dialog> </hd-flex>
//變數
url: `${conf.BASE_URL}/core/ssqd/importS`,
isUploadDialog: false,
fileList: [],
// 方法
//匯入
async importS() {
this.fileList=[];
this.isUploadDialog=true;
},
success(response, file, fileList){
if(response.code=='500'){
this.$hd.message.error(response.errorBody.errorMessage);
}
if(response.code=='200'){
this.$hd.message.ok('匯入成功!');
this.isUploadDialog=false;
this.$refs.table.onSearch();
}
},
error(err, file, fileList){
this.$hd.message.error(err);
},
handleRemove(file, fileList) {
console.log(file, fileList)
},
handlePreview(file) {
console.log(file)
},
handleExceed(files, fileList) {
this.$message.warning(
`當前限制選擇 1 個檔案,本次選擇了 ${files.length} 個檔案,共選擇了 ${
files.length + fileList.length
} 個檔案`
)
},
beforeRemove(file, fileList) {
return this.$confirm(`確定移除 ${file.name}?`)
},
Java
Controller
@ApiOperation("上傳")
@ApiImplicitParams({
@ApiImplicitParam(name = "file",value = "https://www.cnblogs.com/lilulin/p/檔案",dataTypeClass = MultipartFile.class,required = true,paramType = "")
})
@PostMapping ("/importS")
public RestResponse<String> uploadExcel(MultipartFile file)throws IOException {
String HZ = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
if(".xlsx.xls".indexOf(HZ) < 0){
throw new BaseException("500","匯入的檔案型別不正確,只能匯入Excel檔案");
}
EasyExcel.read(file.getInputStream(), SsqdVO.class,new UploadListenerBySsqd(iSsqdService)).sheet() .doRead();;
return new RestResponse<> ("ok");
}
javaBean
package com.hopedove.coreserver.vo.sygl;
import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;
import com.hopedove.commons.vo.BaseModel;
import lombok.Data;
/**
* 璇曠罕娓呭崟
* @TableName T_JS_SYGL_SSQD
*/
@TableName(value ="https://www.cnblogs.com/lilulin/p/T_JS_SYGL_SSQD")
@Data
public class SsqdVO extends BaseModel implements Serializable {
/**
* 璇曠罕娓呭崟ID
*/
@TableId
private String SSQDID;
/**
* 坯布型別
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/試紗型別", index = 0)
private String PBLX;
/**
* 布號
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/布號", index = 1)
private String BH;
/**
* 支數
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/支數", index = 2)
private String ZS;
/**
* 產地
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/產地", index = 3)
private String CD;
/**
* 批號
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/批號", index = 4)
private String PH;
/**
* 重量
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/重量", index = 5)
private BigDecimal ZL;
/**
* 備注
*/
@ExcelProperty(value ="https://www.cnblogs.com/lilulin/p/備注", index = 6)
private String REMARK;
@TableField(exist = false)
private String GY;
}
監聽器: 判斷上傳表格是否符合要求
package com.hopedove.coreserver.service.impl.sygl;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.nacos.common.utils.CollectionUtils;
import com.hedu.sweet.starter.utils.exception.BusinException;
import com.hopedove.coreserver.service.sygl.ISsqdService;
import com.hopedove.coreserver.vo.sygl.SsqdVO;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public class UploadListenerBySsqd extends AnalysisEventListener<SsqdVO> {
private ISsqdService iSsqdService;
public UploadListenerBySsqd(ISsqdService iSsqdService) {
this.iSsqdService = iSsqdService;
}
private List<SsqdVO> list = new ArrayList<>(100);
@Override
public void invoke(SsqdVO ssqdVO, AnalysisContext analysisContext) {
//業務判斷
System.out.println("***"+ssqdVO+"***");
list.add(ssqdVO);
// if (list.size() > 100) {
// wjgbpclService.saveData(list);//保存到資料庫
// list = ListUtils.newArrayListWithExpectedSize(100);
// }
}
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
if (CollectionUtils.isNotEmpty(list)) {
System.out.println("***結束***");
System.out.println(list);
iSsqdService.saveData(list);
}else{
throw new BusinException("500","匯入的檔案為空,請填寫資訊后重新匯入,");
}
}
/**
* 在這里進行模板的判斷
* @param headMap 存放著匯入表格的表頭,鍵是索引,值是名稱
* @param context
*/
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
String isNull = "";
if (context.readRowHolder().getRowIndex() == 0) {
String[] headList = {"試紗型別","布號","支數","產地","批號","重量","備注"};
for (int i = 0; i < headList.length; i++) {
try {
if (!headMap.get(i).equals(headList[i])) {
isNull = "匯入模板不正確,請重新匯入";
break;
}
} catch (Exception e) {
isNull = "匯入模板不正確,請重新匯入";
break;
}
}
}
if(isNull!=""){
throw new BusinException("500",isNull);
}
}
}
實作類
@Override
public void saveData(List<SsqdVO> list) {
//出現空的資料行,只有邊框沒有值-處理
list = tableNullLineRemove(list);
String msg = "";
if(list.size() > 0){
if (StringUtil.isEmpty(msg)) {
// 驗證輸入資料重復性
msg = checkMxList(list);
}
if (StringUtil.isEmpty(msg)) {
// excel資料插入資料庫
List<SsqdVO> arr = new ArrayList<>(100);
for (int i = 0; i < list.size(); i++) {
SsqdVO bean= list.get(i);
bean = nullToString(bean);
arr.add(bean);
}
if (CollectionUtils.isNotEmpty(list)) {
if(!importAdd(list)){//匯入
throw new BusinException("500","匯入的檔案有效記錄數超過1000條,請分批次多次匯入");
}
}
}
}
if(!StringUtil.isEmpty(msg)){
throw new BusinException("500",msg);
}
}
/**
* 驗證輸入資料重復性
* @param list
* @return
*/
private String checkMxList(List<SsqdVO> list) {
List<String> errMsgList = new ArrayList<String>();
String msg = "";
if (list.size() > 0) {
// 把頁面的資料進行重復性檢驗
for (int i = 0; i < list.size(); i++) {
SsqdVO mxModel = list.get(i);
String PBLX = StringUtil.nullToSring(mxModel.getPBLX());
String BH = StringUtil.nullToSring(mxModel.getBH());
String ZS = StringUtil.nullToSring(mxModel.getZS());
String ZL = StringUtil.nullToSring(mxModel.getZL());
//當紗織型別,布號,支數和重量都為空,那么這條記錄既不交驗,也不添加
if(StringUtil.isEmpty(PBLX) && StringUtil.isEmpty(BH) && StringUtil.isEmpty(ZS) && StringUtil.isEmpty(ZL)){
continue;
}
for (int j = 1; j < list.size(); j++) {
if (i != j) {
SsqdVO mxModelSec = list.get(j);
String PBLXsec = mxModelSec.getPBLX();
String BHsec = StringUtil.nullToSring(mxModelSec.getBH());
String ZSsec = StringUtil.nullToSring(mxModelSec.getZS());
String ZLsec = StringUtil.nullToSring(mxModelSec.getZL());
//當紗織型別,布號,支數和重量都為空,那么這條記錄既不交驗,也不添加
if(StringUtil.isEmpty(PBLXsec) && StringUtil.isEmpty(BHsec) && StringUtil.isEmpty(ZSsec) && StringUtil.isEmpty(ZLsec)){
continue;
}
if(PBLX.equals(PBLXsec) && "2".equals(PBLX)){
if ((StringUtil.nullToSring(mxModelSec.getBH()))
.equals(StringUtil.nullToSring(mxModel.getBH()))
&& (StringUtil.nullToSring(mxModelSec.getZS()))
.equals(StringUtil.nullToSring(mxModel.getZS()))
&& (StringUtil.nullToSring(mxModelSec.getZL()))
.equals(StringUtil.nullToSring(mxModel.getZL()))
&& (StringUtil.nullToSring(mxModelSec.getSC()))
.equals(StringUtil.nullToSring(mxModel.getSC()))
&& (StringUtil.nullToSring(mxModelSec.getSH()))
.equals(StringUtil.nullToSring(mxModel.getSH()))
&& (StringUtil.nullToSring(mxModelSec.getGY()))
.equals(StringUtil.nullToSring(mxModel.getGY()))) {
msg="匯入檔案第" + (i+1) + "行資料記錄與第" + (j+1)
+ "行資料記錄重復</br>";
/*errMsgList.add("匯入檔案第" + (i+1) + "行資料記錄與第" + j
+ "行資料記錄重復</br>");*/
}
} else {
if ((StringUtil.nullToSring(mxModelSec.getBH()))
.equals(StringUtil.nullToSring(mxModel.getBH()))
&& (StringUtil.nullToSring(mxModelSec.getZS()))
.equals(StringUtil.nullToSring(mxModel.getZS()))
&& (StringUtil.nullToSring(mxModelSec.getZL()))
.equals(StringUtil.nullToSring(mxModel.getZL()))) {
msg="匯入檔案第" + (i+1) + "行資料記錄與第" + (j+1)
+ "行資料記錄重復</br>";
/*errMsgList.add("匯入檔案第" + (i+1) + "行資料記錄與第" + j
+ "行資料記錄重復</br>")*/;
}
}
}
}
}
}
return msg;
}
private Boolean importAdd(List<SsqdVO> list) {
UserDTO userBean = UserUtil.getUserInfo();
int index = 0 ;
List <Map <String, String>> addList = new ArrayList <Map <String, String>>();
for (int i = 0; i < list.size(); i++) {
SsqdVO entry = list.get(i);
//保存的處理邏輯
}
iSsqdDao.insertSSQD(addList);
iSsqdDao.insertSSRZGY(addList);
return true;
}
private SsqdVO nullToString(SsqdVO params) {
Map<String,Object> map = new HashMap<>();
Field[] fields = params.getClass().getDeclaredFields();
try {
for (Field field : fields
) {
//設定允許通過反射訪問私有變數
field.setAccessible(true);
map.put(field.getName(),field.get(params)==null? "":field.get(params));
}
}catch (Exception e){
e.printStackTrace();
}
return MapUntil.mapToBean(map,new SsqdVO());
}
private List<SsqdVO> tableNullLineRemove(List<SsqdVO> list) {
List<SsqdVO> l = new ArrayList<>();
//當紗織型別,布號,支數和重量都為空,那么這條記錄既不交驗,也不添加
for (SsqdVO model:list
) {
if(model.getPBLX()==null && model.getBH() ==null&&model.getZS()==null &&model.getZL()==null){
continue;
}else{
l.add(model);
}
}
return l;
}
SQL oracle資料庫批量新增
<insert id="insertSSQD" parameterType="list"> insert all <foreach collection="list" item="item"> <![CDATA[ into T_JS_SYGL_SSQD ( SSQDID, RSQDBH, BH, PBLX, PBMC, ZS, CREATER, CRENAME, UPDATER, BMXXID, BMMC, JGXXID, JGMC, ZTXXID, ZTMC ]]> <if test=" item.ZL != null and item.ZL != '' ">,ZL </if> <if test=" item.SH != null and item.SH != '' ">,SH </if> <if test=" item.ZFMYQ != null and item.ZFMYQ != '' ">,ZFMYQ </if> <if test=" item.XSYQ != null and item.XSYQ != '' ">,XSYQ </if> <if test=" item.SG != null and item.SG != '' ">,SG </if> <if test=" item.REMARK != null and item.REMARK != '' ">,REMARK </if> <if test=" item.CD != null and item.CD != '' ">,CD </if> <if test=" item.PH != null and item.PH != '' ">,PH </if> <if test=" item.SC != null and item.SC != '' ">,SC </if> ) VALUES( <![CDATA[ #{item.SSQDID}, #{item.RSQDBH}, #{item.BH}, #{item.PBLX}, #{item.PBMC}, #{item.ZS}, #{item.CREATER}, #{item.CRENAME}, #{item.UPDATER}, #{item.BMXXID}, #{item.BMMC}, #{item.JGXXID}, #{item.JGMC}, #{item.ZTXXID}, #{item.ZTMC} ]]> <if test=" item.ZL != null and item.ZL != '' ">,#{item.ZL} </if> <if test=" item.SH != null and item.SH != '' ">,#{item.SH} </if> <if test=" item.ZFMYQ != null and item.ZFMYQ != '' ">,#{item.ZFMYQ} </if> <if test=" item.XSYQ != null and item.XSYQ != '' ">,#{item.XSYQ} </if> <if test=" item.SG != null and item.SG != '' ">,#{item.SG} </if> <if test=" item.REMARK != null and item.REMARK != '' ">,#{item.REMARK} </if> <if test=" item.CD != null and item.CD != '' ">,#{item.CD} </if> <if test=" item.PH != null and item.PH != '' ">,#{item.PH} </if> <if test=" item.SC != null and item.SC != '' ">,#{item.SC} </if> ) </foreach> select * from dual </insert>
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/554126.html
標籤:Java
下一篇:返回列表
