第三方产品信息导入

dev_ksck_axxyy
anthonywj 11 months ago
parent ffe4a8013e
commit 003fbc5205

@ -372,6 +372,27 @@
<artifactId>redisson</artifactId> <artifactId>redisson</artifactId>
<version>3.6.0</version> <version>3.6.0</version>
</dependency> </dependency>
<!--解析excel-->
<!--xls-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.0.0</version>
</dependency>
<!--xlsx-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.0</version>
</dependency>
<!--excel-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.2.10</version>
</dependency>
</dependencies> </dependencies>
<build> <build>

@ -3,6 +3,7 @@ package com.glxp.api.controller.thrsys;
import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil; import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.io.IoUtil;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONUtil; import cn.hutool.json.JSONUtil;
import com.github.pagehelper.PageInfo; import com.github.pagehelper.PageInfo;
@ -11,12 +12,10 @@ import com.glxp.api.annotation.Log;
import com.glxp.api.common.enums.ResultEnum; import com.glxp.api.common.enums.ResultEnum;
import com.glxp.api.common.res.BaseResponse; import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.common.util.ResultVOUtils; import com.glxp.api.common.util.ResultVOUtils;
import com.glxp.api.constant.BasicProcessStatus;
import com.glxp.api.constant.BusinessType; import com.glxp.api.constant.BusinessType;
import com.glxp.api.entity.auth.AuthAdmin; import com.glxp.api.entity.auth.AuthAdmin;
import com.glxp.api.entity.basic.BasicNewUploadDiEntity; import com.glxp.api.entity.basic.*;
import com.glxp.api.entity.basic.CompanyProductRelevanceEntity;
import com.glxp.api.entity.basic.UdiProductEntity;
import com.glxp.api.entity.basic.UdiRelevanceEntity;
import com.glxp.api.entity.thrsys.ThrProductsAddDiEntity; import com.glxp.api.entity.thrsys.ThrProductsAddDiEntity;
import com.glxp.api.entity.thrsys.ThrProductsEntity; import com.glxp.api.entity.thrsys.ThrProductsEntity;
import com.glxp.api.entity.thrsys.ThrSystemEntity; import com.glxp.api.entity.thrsys.ThrSystemEntity;
@ -27,6 +26,7 @@ import com.glxp.api.req.system.DeleteRequest;
import com.glxp.api.req.thrsys.AddThrDiProductsRequest; import com.glxp.api.req.thrsys.AddThrDiProductsRequest;
import com.glxp.api.req.thrsys.FilterThrProductsRequest; import com.glxp.api.req.thrsys.FilterThrProductsRequest;
import com.glxp.api.res.PageSimpleResponse; import com.glxp.api.res.PageSimpleResponse;
import com.glxp.api.res.basic.BasicCorpExportLogResponse;
import com.glxp.api.res.basic.UdiRelevanceResponse; import com.glxp.api.res.basic.UdiRelevanceResponse;
import com.glxp.api.res.thrsys.ThrProductsAddDiResponse; import com.glxp.api.res.thrsys.ThrProductsAddDiResponse;
import com.glxp.api.res.thrsys.UdiInfoResponse; import com.glxp.api.res.thrsys.UdiInfoResponse;
@ -42,15 +42,14 @@ import com.glxp.api.util.IntUtil;
import com.glxp.api.util.SupplementVailUtil; import com.glxp.api.util.SupplementVailUtil;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.validation.BindingResult; import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes; import org.springframework.web.context.request.ServletRequestAttributes;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -468,5 +467,33 @@ public class ThrProductsAddDiController {
return ResultVOUtils.success("更新成功"); return ResultVOUtils.success("更新成功");
} }
@AuthRuleAnnotation("")
@Log(title = "入院物资申请导入", businessType = BusinessType.UPDATE)
@PostMapping("/spms/thrAddDi/excel/upload")
public BaseResponse uploadCorp(@RequestParam("file") MultipartFile file) {
// String filePath = "D:\\udiwms\\filePath\\";
// File createFile = new File(filePath);
// if (!createFile.exists()) {
// createFile.mkdirs();
// }
// if (file.isEmpty()) {
// return ResultVOUtils.error(500, "上传第" + (i++) + "个文件失败");
// }
String customerId = getCustomerId();
String fileName = file.getOriginalFilename();
//解析数据
try {
String fileType = fileName.substring(fileName.lastIndexOf("."));
if (".xlsx".equalsIgnoreCase(fileType) || ".xls".equalsIgnoreCase(fileType)) {
thrProductsAddDiService.excelImport(file, Long.valueOf(customerId));
} else {
return ResultVOUtils.error(500, "请上传xlsx,xls文件");
}
} catch (Exception e) {
log.error("导入产品信息错误,文件名为:{}", fileName);
}
return ResultVOUtils.success("上传成功");
}
} }

@ -70,6 +70,14 @@ public class ThrProductsAddDiEntity {
@ApiModelProperty(value = "审核状态") @ApiModelProperty(value = "审核状态")
private Integer status; private Integer status;
/**
*
*/
@TableField(value = "`addStatus`")
@ApiModelProperty(value = "导入状态")
private Integer addStatus;
@TableField(value = "thirdSysFk") @TableField(value = "thirdSysFk")
@ApiModelProperty(value = "") @ApiModelProperty(value = "")
private String thirdSysFk; private String thirdSysFk;

@ -0,0 +1,37 @@
package com.glxp.api.req.thrsys;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
@Data
public class AddThrDiProductsExcelVo {
@ExcelProperty("DI最小销售产品标识")
private String nameCode;
@ExcelProperty("商品条码")
private String sptm;
@ExcelProperty("医保编码")
private String ybbm;
@ExcelProperty("计量单位")
private String measname;
@ExcelProperty("生产企业")
private String manufactory;
@ExcelProperty("商品名称")
private String spmc;
@ExcelProperty("产品描述")
private String cpms;
@ExcelProperty("产品价格")
private String price;
@ExcelProperty("是否集采(是/否)")
private String groupBuy;
@ExcelProperty("采购类型(普通入账/预验收/寄售)")
private String purType;
@ExcelProperty("产品属性(设备/耗材/服务费)")
private String attributeType;
@ExcelProperty("耗材类型(高值/低值)")
private String hcType;
@ExcelProperty("收费码")
private String basicPrductRemak1;
}

@ -30,8 +30,7 @@ public class AddThrDiProductsRequest {
private Long customerId; private Long customerId;
private String thirdSysFk;
private String code;
private String sptm; private String sptm;
private String ybbm; private String ybbm;
private String measname; private String measname;
@ -94,4 +93,8 @@ public class AddThrDiProductsRequest {
private String catalogcode; private String catalogcode;
private String thirdSysFk;
private String code;
} }

@ -51,6 +51,5 @@ public class ThrProductsAddDiResponse extends ThrProductsAddDiEntity {
private String matrial; private String matrial;
private String deviceRecordKey; private String deviceRecordKey;
} }

@ -53,4 +53,7 @@ public interface ProductInfoService {
boolean updateProductInfo(ProductInfoEntity productInfoEntity); boolean updateProductInfo(ProductInfoEntity productInfoEntity);
ProductInfoEntity findByNameCode(String nameCode);
} }

@ -199,7 +199,7 @@ public class UdiContrastService {
udiRelevanceEntity.setUuid(CustomUtil.getUUId()); udiRelevanceEntity.setUuid(CustomUtil.getUUId());
udiRelevanceEntity.setSupName(thrProductsEntity.getSupName()); udiRelevanceEntity.setSupName(thrProductsEntity.getSupName());
udiRelevanceEntity.setId(gennerOrderUtils.getRelId()); udiRelevanceEntity.setId(gennerOrderUtils.getRelId());
udiRelevanceEntity.setIsDisable(true); udiRelevanceEntity.setIsDisable(false);
udiRelevanceService.insertUdiRelevance(udiRelevanceEntity); udiRelevanceService.insertUdiRelevance(udiRelevanceEntity);
UdiProductEntity udiProductEntity = new UdiProductEntity(); UdiProductEntity udiProductEntity = new UdiProductEntity();
BeanUtils.copyProperties(thrProductsEntity, udiProductEntity); BeanUtils.copyProperties(thrProductsEntity, udiProductEntity);
@ -230,7 +230,7 @@ public class UdiContrastService {
udiRelevanceEntity.setUuid(CustomUtil.getUUId()); udiRelevanceEntity.setUuid(CustomUtil.getUUId());
udiRelevanceEntity.setSupName(thrProductsAddDiEntity.getSupName()); udiRelevanceEntity.setSupName(thrProductsAddDiEntity.getSupName());
udiRelevanceEntity.setId(gennerOrderUtils.getRelId()); udiRelevanceEntity.setId(gennerOrderUtils.getRelId());
udiRelevanceEntity.setIsDisable(true); udiRelevanceEntity.setIsDisable(false);
udiRelevanceEntity.setNewNeedUpload(true); udiRelevanceEntity.setNewNeedUpload(true);
udiRelevanceService.insertUdiRelevance(udiRelevanceEntity); udiRelevanceService.insertUdiRelevance(udiRelevanceEntity);
UdiProductEntity udiProductEntity = new UdiProductEntity(); UdiProductEntity udiProductEntity = new UdiProductEntity();

@ -1,6 +1,7 @@
package com.glxp.api.service.basic.impl; package com.glxp.api.service.basic.impl;
import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageHelper;
import com.glxp.api.dao.basic.ProductInfoDao; import com.glxp.api.dao.basic.ProductInfoDao;
import com.glxp.api.entity.basic.ProductInfoEntity; import com.glxp.api.entity.basic.ProductInfoEntity;
@ -196,6 +197,15 @@ public class ProductInfoServiceImpl implements ProductInfoService {
return productInfoDao.updateProductInfo(productInfoEntity); return productInfoDao.updateProductInfo(productInfoEntity);
} }
@Override
public ProductInfoEntity findByNameCode(String nameCode) {
ProductInfoFilterRequest productInfoFilterRequest = new ProductInfoFilterRequest();
productInfoFilterRequest.setNameCode(nameCode);
List<ProductInfoEntity> productInfoEntities = productInfoDao.filterProductGroup(productInfoFilterRequest);
return CollUtil.isNotEmpty(productInfoEntities) ? productInfoEntities.get(0) : null;
}
@Override @Override
public boolean deleteById(String id) { public boolean deleteById(String id) {
return productInfoDao.deleteById(id); return productInfoDao.deleteById(id);

@ -5,6 +5,7 @@ import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONUtil; import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageHelper;
import com.glxp.api.dao.auth.AuthCompanyMapper; import com.glxp.api.dao.auth.AuthCompanyMapper;
@ -14,20 +15,26 @@ import com.glxp.api.entity.auth.AuthCompany;
import com.glxp.api.entity.basic.ProductInfoEntity; import com.glxp.api.entity.basic.ProductInfoEntity;
import com.glxp.api.entity.thrsys.ThrHslbEntity; import com.glxp.api.entity.thrsys.ThrHslbEntity;
import com.glxp.api.entity.thrsys.ThrProductsAddDiEntity; import com.glxp.api.entity.thrsys.ThrProductsAddDiEntity;
import com.glxp.api.req.thrsys.AddThrDiProductsExcelVo;
import com.glxp.api.req.thrsys.AddThrDiProductsRequest; import com.glxp.api.req.thrsys.AddThrDiProductsRequest;
import com.glxp.api.req.thrsys.FilterThrProductsRequest; import com.glxp.api.req.thrsys.FilterThrProductsRequest;
import com.glxp.api.res.thrsys.ThrProductsAddDiResponse; import com.glxp.api.res.thrsys.ThrProductsAddDiResponse;
import com.glxp.api.res.thrsys.UdiInfoResponse; import com.glxp.api.res.thrsys.UdiInfoResponse;
import com.glxp.api.service.basic.ProductInfoService; import com.glxp.api.service.basic.ProductInfoService;
import com.glxp.api.service.thrsys.ThrHslbService; import com.glxp.api.service.thrsys.ThrHslbService;
import com.glxp.api.util.Excel.ExcelHandler;
import com.glxp.api.util.Excel.Exception.RenException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@Slf4j
@Service @Service
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, ThrProductsAddDiEntity> { public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, ThrProductsAddDiEntity> {
@ -96,7 +103,6 @@ public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, Th
public boolean addThrAddDiProducts(AddThrDiProductsRequest thrDiProductsRequest) { public boolean addThrAddDiProducts(AddThrDiProductsRequest thrDiProductsRequest) {
List<String> uuids = thrDiProductsRequest.getUuids(); List<String> uuids = thrDiProductsRequest.getUuids();
Long customerId = thrDiProductsRequest.getCustomerId(); Long customerId = thrDiProductsRequest.getCustomerId();
List<ThrProductsAddDiEntity> list = new ArrayList<>(uuids.size()); List<ThrProductsAddDiEntity> list = new ArrayList<>(uuids.size());
@ -105,9 +111,7 @@ public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, Th
ProductInfoEntity productInfoEntity = productInfoService.selectByUuid(uuid).get(0); ProductInfoEntity productInfoEntity = productInfoService.selectByUuid(uuid).get(0);
ThrProductsAddDiEntity thrProductsAddDiEntity = new ThrProductsAddDiEntity(); ThrProductsAddDiEntity thrProductsAddDiEntity = new ThrProductsAddDiEntity();
BeanUtil.copyProperties(thrDiProductsRequest, thrProductsAddDiEntity); BeanUtil.copyProperties(thrDiProductsRequest, thrProductsAddDiEntity);
thrProductsAddDiEntity.setCustomerId(customerId); if (productInfoEntity != null) {
thrProductsAddDiEntity.setUuid(uuid);
thrProductsAddDiEntity.setType(1);
thrProductsAddDiEntity.setYlqxzcrbarywmc(productInfoEntity.getYlqxzcrbarywmc()); thrProductsAddDiEntity.setYlqxzcrbarywmc(productInfoEntity.getYlqxzcrbarywmc());
thrProductsAddDiEntity.setCplb(productInfoEntity.getCplb()); thrProductsAddDiEntity.setCplb(productInfoEntity.getCplb());
thrProductsAddDiEntity.setCpms(productInfoEntity.getCpms()); thrProductsAddDiEntity.setCpms(productInfoEntity.getCpms());
@ -122,6 +126,13 @@ public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, Th
thrProductsAddDiEntity.setYlqxzcrbarmc(productInfoEntity.getYlqxzcrbarmc()); thrProductsAddDiEntity.setYlqxzcrbarmc(productInfoEntity.getYlqxzcrbarmc());
thrProductsAddDiEntity.setDeviceRecordKey(productInfoEntity.getDeviceRecordKey()); thrProductsAddDiEntity.setDeviceRecordKey(productInfoEntity.getDeviceRecordKey());
thrProductsAddDiEntity.setZczbhhzbapzbh(productInfoEntity.getZczbhhzbapzbh()); thrProductsAddDiEntity.setZczbhhzbapzbh(productInfoEntity.getZczbhhzbapzbh());
thrProductsAddDiEntity.setAddStatus(1);
} else {
thrProductsAddDiEntity.setAddStatus(2);
}
thrProductsAddDiEntity.setCustomerId(customerId);
thrProductsAddDiEntity.setUuid(uuid);
thrProductsAddDiEntity.setType(1);
thrProductsAddDiEntity.setGroupBuy(thrDiProductsRequest.getGroupBuy()); thrProductsAddDiEntity.setGroupBuy(thrDiProductsRequest.getGroupBuy());
//设置编辑区参数 //设置编辑区参数
thrProductsAddDiEntity.setSptm(thrDiProductsRequest.getSptm()); thrProductsAddDiEntity.setSptm(thrDiProductsRequest.getSptm());
@ -148,7 +159,6 @@ public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, Th
thrProductsAddDiEntity.setCatalogCode2(catalogcode2); thrProductsAddDiEntity.setCatalogCode2(catalogcode2);
thrProductsAddDiEntity.setCatalogCode3(catalogcode3); thrProductsAddDiEntity.setCatalogCode3(catalogcode3);
} }
list.add(thrProductsAddDiEntity); list.add(thrProductsAddDiEntity);
} }
return thrProductsAddDiDao.insertThrDiProducts(list); return thrProductsAddDiDao.insertThrDiProducts(list);
@ -213,4 +223,79 @@ public class ThrProductsAddDiService extends ServiceImpl<ThrProductsAddDiDao, Th
public List<ThrProductsAddDiEntity> filterThrProductsDiLists(FilterThrProductsRequest filterThrProductsRequest) { public List<ThrProductsAddDiEntity> filterThrProductsDiLists(FilterThrProductsRequest filterThrProductsRequest) {
return thrProductsAddDiDao.filterThrProductsDiLists(filterThrProductsRequest); return thrProductsAddDiDao.filterThrProductsDiLists(filterThrProductsRequest);
} }
@Resource
ExcelHandler excelHandler;
public void excelImport(MultipartFile multipartFile, Long customerId) {
try {
List<AddThrDiProductsExcelVo> voList = excelHandler.importExcel(multipartFile, AddThrDiProductsExcelVo.class, null);
if (CollectionUtils.isNotEmpty(voList)) {
log.info("本次成功入:" + voList.size() + "条,数据如下---------------");
voList.forEach(excelVo -> {
ProductInfoEntity productInfoEntity = productInfoService.findByNameCode(excelVo.getNameCode());
AddThrDiProductsRequest addThrDiProductsRequest = new AddThrDiProductsRequest();
if (productInfoEntity != null) {
addThrDiProductsRequest.setUuids(List.of(productInfoEntity.getUuid()));
} else {
addThrDiProductsRequest.setUuids(List.of("null"));
}
//todo
addThrDiProductsRequest.setSptm(excelVo.getSptm());
addThrDiProductsRequest.setManufactory(excelVo.getManufactory());
addThrDiProductsRequest.setCpms(excelVo.getCpms());
addThrDiProductsRequest.setMeasname(excelVo.getMeasname());
addThrDiProductsRequest.setPrice(excelVo.getPrice());
addThrDiProductsRequest.setBasicPrductRemak1(excelVo.getBasicPrductRemak1());
addThrDiProductsRequest.setSpmc(excelVo.getSpmc());
addThrDiProductsRequest.setYbbm(excelVo.getYbbm());
addThrDiProductsRequest.setCustomerId(customerId);
if (StrUtil.isNotEmpty(excelVo.getAttributeType())) {
if (excelVo.getAttributeType().equals("设备")) {
addThrDiProductsRequest.setAttributeType(1);
} else if (excelVo.getAttributeType().equals("耗材")) {
addThrDiProductsRequest.setAttributeType(2);
} else if (excelVo.getAttributeType().equals("服务费")) {
addThrDiProductsRequest.setAttributeType(3);
}
}
if (StrUtil.isNotEmpty(excelVo.getGroupBuy())) {
if (excelVo.getGroupBuy().equals("是")) {
addThrDiProductsRequest.setGroupBuy(true);
} else
addThrDiProductsRequest.setGroupBuy(false);
}
if (StrUtil.isNotEmpty(excelVo.getHcType())) {
if (excelVo.getHcType().equals("高值")) {
addThrDiProductsRequest.setHcType(1);
} else if (excelVo.getHcType().equals("低值")) {
addThrDiProductsRequest.setHcType(2);
}
}
if (StrUtil.isNotEmpty(excelVo.getPurType())) {
if (excelVo.getPurType().equals("普通入账")) {
addThrDiProductsRequest.setPurType(1);
}
if (excelVo.getPurType().equals("预验收")) {
addThrDiProductsRequest.setPurType(2);
} else
addThrDiProductsRequest.setPurType(3);
}
addThrAddDiProducts(addThrDiProductsRequest);
//1.校验国家库信息
// addThrDiProductsRequest.setAttributeType();
});
}
} catch (Exception e) {
throw new RenException("导入失败");
}
}
} }

@ -0,0 +1,288 @@
package com.glxp.api.util.Excel;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.EasyExcelFactory;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.read.builder.ExcelReaderBuilder;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.excel.write.metadata.fill.FillConfig;
import com.glxp.api.util.Excel.Exception.RenException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
@Slf4j
@Component
public class ExcelHandler {
/**
* excel
*
* @param file
* @param clazz
* @param sheetNamesheet [sheet]
* @throws Exception
*/
public <T> List<T> importExcel(MultipartFile file, Class<T> clazz, String sheetName) throws Exception {
this.checkFile(file);
UploadDataListener<T> uploadDataListener = new UploadDataListener<>();
ExcelReaderBuilder builder = EasyExcelFactory.read(file.getInputStream(), clazz, uploadDataListener);
if (StringUtils.isEmpty(sheetName)) {
builder.sheet().doRead();
} else {
builder.sheet(sheetName).doRead();
}
return uploadDataListener.getList();
}
/**
* sheet
*
* @param multipartFile
* @param objList sheet
* @param index sheet
* @param indexList sheet
* @param <T>
* @return <T> List<List<T>>
* @throws Exception
*/
public <T> List<List<T>> importExcelsByIndex(MultipartFile multipartFile, List<T> objList, int index, List<Integer> indexList) throws Exception {
if (multipartFile == null) {
throw new RenException("文件为空");
}
List<List<T>> resultList = new LinkedList<>();
//初始化导入sheet页实体类型下标
int objListClass = 0;
for (int i = 0; i < index; i++) {
if (indexList.contains(i)) {
UploadDataListener<T> uploadDataListener = new UploadDataListener<>();
List<T> excels;
EasyExcelFactory.read(multipartFile.getInputStream(), objList.get(objListClass).getClass(), uploadDataListener).sheet(i).doRead();
excels = uploadDataListener.getList();
resultList.add(excels);
objListClass++;
}
}
return resultList;
}
/**
* sheet
*
* @param file
* @param indexsheet [030 1 2]
* @param paramssheet[index33]
* @param <T>
* @return
*/
public <T> List<List<T>> importExcels(MultipartFile file, int index, List<Object> params) throws Exception {
this.checkFile(file);
List<List<T>> resultList = new LinkedList<>();
for (int i = 0; i < index; i++) {
UploadDataListener<T> uploadDataListener = new UploadDataListener<>();
ExcelReaderBuilder builder = EasyExcelFactory.read(file.getInputStream(), params.get(i).getClass(), uploadDataListener);
builder.sheet(i).doRead();
List<T> list = uploadDataListener.getList();
resultList.add(list);
}
return resultList;
}
/**
* excel
*
* @param response
* @param dataList
* @param clazz
* @param fileName
* @param sheetNamesheet
* @throws Exception
*/
public <T> void exportExcel(HttpServletResponse response, List<T> dataList, Class<T> clazz, String fileName, String sheetName) throws Exception {
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8.name());
response.setHeader("Content-disposition", "attachment;filename=" + fileName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc());
ServletOutputStream outputStream = response.getOutputStream();
EasyExcelFactory.write(outputStream, clazz).sheet(sheetName).doWrite(dataList);
outputStream.flush();
outputStream.close();
}
/**
* sheet
*
* @param response
* @param dataList
* @param clazzMapsheet
* @param fileName
* @param <T>
* @throws Exception
*/
public <T> void exportExcels(HttpServletResponse response, List<List<?>> dataList, Map<Integer, String> clazzMap, String fileName) throws Exception {
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8.name());
response.setHeader("Content-disposition", "attachment;filename=" + fileName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc());
ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).build();
int len = dataList.get(0).size();
for (int i = 0; i < len; i++) {
List<?> objects = (List<?>) dataList.get(0).get(i);
Class<?> aClass = objects.get(0).getClass();
WriteSheet writeSheet0 = EasyExcel.writerSheet(i, clazzMap.get(i)).head(aClass).build();
excelWriter.write(objects, writeSheet0);
}
excelWriter.finish();
}
/**
* -sheet
*
* @param list
* @param object
* @param fileName
* @param templateName
* @throws Exception
*/
public <T> void exportTemplateExcels(HttpServletResponse response, List<T> list, Object object, String fileName, String templateName) throws Exception {
String template = ExcelTemplateEnum.TEMPLATE_PATH.getDesc() + File.separator + templateName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc();
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream(template);
FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
ExcelWriter excelWriter = EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).build();
WriteSheet writeSheet0 = EasyExcelFactory.writerSheet(0).build();
excelWriter.fill(object, fillConfig, writeSheet0);
excelWriter.fill(list, fillConfig, writeSheet0);
excelWriter.finish();
}
/**
* -sheet
*
* @param list1
* @param list2
* @param object1
* @param object2
* @param fileName
* @param templateName
* @throws Exception
*/
public <T> void exportSheetTemplateExcels(HttpServletResponse response, List<T> list1, List<T> list2, Object object1, Object object2, String fileName, String templateName) throws Exception {
String template = ExcelTemplateEnum.TEMPLATE_PATH.getDesc() + File.separator + templateName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc();
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream(template);
FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
ExcelWriter excelWriter = EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).build();
WriteSheet writeSheet0 = EasyExcelFactory.writerSheet(0).build();
WriteSheet writeSheet1 = EasyExcelFactory.writerSheet(1).build();
excelWriter.fill(object1, fillConfig, writeSheet0);
excelWriter.fill(list1, fillConfig, writeSheet0);
excelWriter.fill(object2, fillConfig, writeSheet1);
excelWriter.fill(list2, fillConfig, writeSheet1);
excelWriter.finish();
}
/**
*
*
* @param object
* @param templateName
* @param fileName
* @param sheetName sheet [sheet]
* @throws Exception
*/
public void exportTemplateExcel(HttpServletResponse response, Object object, String templateName, String fileName, String sheetName) throws Exception {
String template = ExcelTemplateEnum.TEMPLATE_PATH.getDesc() + File.separator + templateName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc();
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream(template);
if (StringUtils.isEmpty(sheetName)) {
EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).sheet().doFill(object);
} else {
EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).sheet(sheetName).doFill(object);
}
}
/**
*
*
* @param list
* @param fileName
* @param templateName
* @param sheetNamesheet [sheet]
* @throws Exception
*/
public <T> void exportTemplateExcelList(HttpServletResponse response, List<T> list, String fileName, String templateName, String sheetName) throws Exception {
log.info("模板名称:{}", templateName);
String template = ExcelTemplateEnum.TEMPLATE_PATH.getDesc() + File.separator + templateName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc();
log.info("模板路径:{}", template);
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream(template);
// 全部填充:全部加载到内存中一次填充
if (StringUtils.isEmpty(sheetName)) {
EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).sheet().doFill(list);
} else {
EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).sheet(sheetName).doFill(list);
}
}
/**
*
*
* @param list
* @param fileName
* @param templateName
* @throws Exception
*/
public <T> void exportTemplateExcel2(HttpServletResponse response, List<T> list, String fileName, String templateName) throws Exception {
String template = ExcelTemplateEnum.TEMPLATE_PATH.getDesc() + File.separator + templateName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc();
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream(template);
ExcelWriter excelWriter = EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).build();
WriteSheet writeSheet = EasyExcelFactory.writerSheet().build();
excelWriter.fill(list, writeSheet);
excelWriter.finish();
}
/**
*
*
* @param fileName
* @param response
* @return
* @throws Exception
*/
private OutputStream getOutputStream(String fileName, HttpServletResponse response) throws Exception {
fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8.name());
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc());
return response.getOutputStream();
}
/**
*
*
* @param file
*/
private void checkFile(MultipartFile file) {
if (file == null) {
throw new RenException("文件不能为空");
}
String fileName = file.getOriginalFilename();
if (StringUtils.isEmpty(fileName)) {
throw new RenException("文件不能为空");
}
if (!fileName.endsWith(ExcelTemplateEnum.TEMPLATE_SUFFIX.getDesc())
&& !fileName.endsWith(ExcelTemplateEnum.TEMPLATE_SUFFIX_XLS.getDesc())) {
throw new RenException("请上传.xlsx或.xls文件");
}
}
}

@ -0,0 +1,67 @@
package com.glxp.api.util.Excel;
import lombok.Getter;
@Getter
public enum ExcelTemplateEnum {
/**
* sheet
*/
TEMPLATE_1("1", "complex"),
/**
*
*/
TEMPLATE_SUFFIX("xlsx", ".xlsx"),
TEMPLATE_SUFFIX_XLS("xls", ".xls"),
TEMPLATE_SUFFIX_DOCX("docx", ".docx"),
/**
*
*/
TEMPLATE_PATH("path", "excel"),
;
private final String code;
private final String desc;
ExcelTemplateEnum(String code, String desc) {
this.code = code;
this.desc = desc;
}
/**
* codemsg
*
* @param code
* @return
*/
public static String getMsgByCode(String code) {
if (code == null) {
return null;
}
ExcelTemplateEnum enumList = getByCode(code);
if (enumList == null) {
return null;
}
return enumList.getDesc();
}
public static String getCode(ExcelTemplateEnum enumList) {
if (enumList == null) {
return null;
}
return enumList.getCode();
}
public static ExcelTemplateEnum getByCode(String code) {
for (ExcelTemplateEnum enumList : values()) {
if (enumList.getCode().equals(code)) {
return enumList;
}
}
return null;
}
}

@ -0,0 +1,56 @@
package com.glxp.api.util.Excel.Exception;
/**
* @author : zhangsan
* @date : 2023/4/17 11:21
* @modyified By :
*/
public class RenException extends RuntimeException {
private static final long serialVersionUID = 1L;
private String msg;
private int code = 500;
public RenException(String msg) {
super(msg);
this.msg = msg;
}
public RenException(String msg, Throwable e) {
super(msg, e);
this.msg = msg;
}
public RenException(String msg, int code) {
super(msg);
this.msg = msg;
this.code = code;
}
public RenException(String msg, int code, Throwable e) {
super(msg, e);
this.msg = msg;
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public int getCode() {
return code;
}
public void setCode(int code) {
this.code = code;
}
}

@ -0,0 +1,61 @@
package com.glxp.api.util.Excel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.excel.exception.ExcelDataConvertException;
import com.glxp.api.util.Excel.Exception.RenException;
import java.util.ArrayList;
import java.util.List;
public class UploadDataListener<T> extends AnalysisEventListener<T> {
/**
*
*/
private final List<T> list = new ArrayList<>();
public List<T> getList() {
return this.list;
}
/**
*
*
* @param object
* @param analysisContext
*/
@Override
public void invoke(T object, AnalysisContext analysisContext) {
this.list.add(object);
}
/**
*
*
* @param analysisContext
*/
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
/**
*
*
* @param exception
* @param context
* @throws Exception
*/
@Override
public void onException(Exception exception, AnalysisContext context) throws Exception {
// 数据解析异常
if (exception instanceof ExcelDataConvertException) {
ExcelDataConvertException excelDataConvertException = (ExcelDataConvertException) exception;
throw new RenException("第" + excelDataConvertException.getRowIndex() + "行" + excelDataConvertException.getColumnIndex() + "列" + "数据解析异常");
}
// 其他异常...
}
}

@ -10,7 +10,7 @@ public class PasswordUtils {
public static String authAdminPwd(String pwd) { public static String authAdminPwd(String pwd) {
// return DigestUtils.md5DigestAsHex(DigestUtils.md5DigestAsHex(pwd.getBytes()).getBytes()).toLowerCase(); // return DigestUtils.md5DigestAsHex(DigestUtils.md5DigestAsHex(pwd.getBytes()).getBytes()).toLowerCase();
return SecureUtil.sha256(pwd); return SecureUtil.sha256(pwd);
// return pwd; // return pwd;-
} }
} }

@ -3,7 +3,7 @@
<mapper namespace="com.glxp.api.dao.thrsys.ThrProductsAddDiDao"> <mapper namespace="com.glxp.api.dao.thrsys.ThrProductsAddDiDao">
<insert id="insertThrDiProducts" keyProperty="id" parameterType="java.util.List"> <insert id="insertThrDiProducts" keyProperty="id" parameterType="java.util.List">
insert into thr_products_add_di (uuid, customerId, createTime, insert ignore into thr_products_add_di (uuid, customerId, createTime,
auditTime, remark, auditUser, auditTime, remark, auditUser,
`status`, thirdSysFk, code, `status`, thirdSysFk, code,
sptm, ybbm, measname, sptm, ybbm, measname,
@ -16,7 +16,8 @@
qxlb, tyshxydm, zczbhhzbapzbh, qxlb, tyshxydm, zczbhhzbapzbh,
ylqxzcrbarmc, ylqxzcrbarywmc, updateTime, ylqxzcrbarmc, ylqxzcrbarywmc, updateTime,
supName, model, `standard`, supName, model, `standard`,
qtbm, zczyxqz, relId, type, deviceRecordKey, groupBuy, purType, attributeType, qtbm, zczyxqz, relId, type, deviceRecordKey, groupBuy, purType,
attributeType,
hcType, hcType,
catalogname1, catalogname1,
catalogname2, catalogname2,
@ -24,7 +25,7 @@
catalogCode1, catalogCode1,
catalogCode2, catalogCode2,
catalogCode3, catalogCode3,
matrial) matrial, addStatus)
values values
<foreach collection="list" index="index" item="item" separator=","> <foreach collection="list" index="index" item="item" separator=",">
(#{item.uuid}, (#{item.uuid},
@ -57,7 +58,7 @@
#{item.catalogCode1}, #{item.catalogCode1},
#{item.catalogCode2}, #{item.catalogCode2},
#{item.catalogCode3}, #{item.catalogCode3},
#{item.matrial}) #{item.matrial}, #{item.addStatus})
</foreach> </foreach>
</insert> </insert>

@ -1,30 +1,33 @@
SET NAMES utf8mb4; SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0; SET FOREIGN_KEY_CHECKS = 0;
DROP TABLE IF EXISTS `sys_db_version`; DROP TABLE IF EXISTS `sys_db_version`;
CREATE TABLE `sys_db_version` ( CREATE TABLE `sys_db_version`
(
`id` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `id` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
`version` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '版本号', `version` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '版本号',
`created` datetime(0) NULL DEFAULT NULL COMMENT '创建时间', `created` datetime(0) NULL DEFAULT NULL COMMENT '创建时间',
`remark` varchar(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '备注', `remark` varchar(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '备注',
PRIMARY KEY (`id`) USING BTREE PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci COMMENT = '数据版本' ROW_FORMAT = Dynamic; ) ENGINE = InnoDB
CHARACTER SET = utf8mb4
COLLATE = utf8mb4_0900_ai_ci COMMENT = '数据版本'
ROW_FORMAT = Dynamic;
SET FOREIGN_KEY_CHECKS = 1; SET FOREIGN_KEY_CHECKS = 1;
/* 创建函数Pro_Temp_ColumnWork操作表字段 */ /* 创建函数Pro_Temp_ColumnWork操作表字段 */
DROP PROCEDURE IF EXISTS Pro_Temp_ColumnWork; DROP PROCEDURE IF EXISTS Pro_Temp_ColumnWork;
CREATE PROCEDURE `Pro_Temp_ColumnWork` ( TableName VARCHAR ( 50 ), ColumnName VARCHAR ( 50 ), SqlStr VARCHAR ( 4000 ), CType INT ) BEGIN CREATE PROCEDURE `Pro_Temp_ColumnWork`(TableName VARCHAR(50), ColumnName VARCHAR(50), SqlStr VARCHAR(4000), CType INT)
BEGIN
DECLARE DECLARE
Rows1 INT; Rows1 INT;
SET Rows1 = 0; SET Rows1 = 0;
SELECT SELECT COUNT(*)
COUNT(*) INTO Rows1 INTO Rows1
FROM FROM INFORMATION_SCHEMA.COLUMNS
INFORMATION_SCHEMA.COLUMNS WHERE table_schema = DATABASE()
WHERE
table_schema = DATABASE ()
AND upper(table_name) = TableName AND upper(table_name) = TableName
AND upper(column_name) = ColumnName; AND upper(column_name) = ColumnName;
IF IF
@ -64,7 +67,8 @@ CREATE PROCEDURE Modify_index (
TableName VARCHAR(50), TableName VARCHAR(50),
ColumnNames VARCHAR(500), ColumnNames VARCHAR(500),
idx_name VARCHAR(50), idx_name VARCHAR(50),
idx_type VARCHAR ( 50 )) BEGIN idx_type VARCHAR(50))
BEGIN
DECLARE DECLARE
Rows1 int; Rows1 int;
DECLARE DECLARE
@ -72,19 +76,19 @@ SqlStr VARCHAR(4000);
DECLARE DECLARE
target_database VARCHAR(100); target_database VARCHAR(100);
SELECT DATABASE SELECT DATABASE
() INTO target_database; ()
INTO target_database;
SET Rows1 = 0; SET Rows1 = 0;
SELECT SELECT COUNT(*)
COUNT(*) INTO Rows1 INTO Rows1
FROM FROM information_schema.statistics
information_schema.statistics WHERE table_schema = DATABASE()
WHERE
table_schema = DATABASE ()
AND upper(table_name) = upper(TableName) AND upper(table_name) = upper(TableName)
AND upper(index_name) = upper(idx_name); AND upper(index_name) = upper(idx_name);
IF Rows1 <= 0 THEN IF Rows1 <= 0 THEN
SET SqlStr := CONCAT( 'alter table ', TableName, ' ADD INDEX ', idx_name, '(', ColumnNames, ') USING ', idx_type ); SET SqlStr :=
CONCAT('alter table ', TableName, ' ADD INDEX ', idx_name, '(', ColumnNames, ') USING ', idx_type);
END IF; END IF;
IF IF
(SqlStr <> '') THEN (SqlStr <> '') THEN
@ -99,3 +103,50 @@ END IF;
END; END;
/*创建定义普通索引函数结束*/ /*创建定义普通索引函数结束*/
/*创建定义唯一索引函数*/
DROP PROCEDURE IF EXISTS Modify_UNIQUE_index;
CREATE PROCEDURE Modify_UNIQUE_index(
TableName VARCHAR(50),
ColumnNames VARCHAR(500),
idx_name VARCHAR(50),
idx_type VARCHAR(50))
BEGIN
DECLARE
Rows1 int;
DECLARE
SqlStr VARCHAR(4000);
DECLARE
target_database VARCHAR(100);
SELECT DATABASE
()
INTO target_database;
SET Rows1 = 0;
SELECT COUNT(*)
INTO Rows1
FROM information_schema.statistics
WHERE table_schema = DATABASE()
AND upper(table_name) = upper(TableName)
AND upper(index_name) = upper(idx_name);
IF Rows1 <= 0 THEN
SET SqlStr :=
CONCAT('alter table ', TableName, ' ADD UNIQUE INDEX ', idx_name, '(', ColumnNames, ') USING ',
idx_type);
END IF;
IF
(SqlStr <> '') THEN
SET @SQL1 = SqlStr;
PREPARE stmt1
FROM
@SQL1;
EXECUTE stmt1;
END IF;
END;
/*创建定义唯一索引函数*/

@ -817,3 +817,6 @@ CALL Pro_Temp_ColumnWork('basic_bussiness_type', 'vailProductAttributes',
'tinyint NULL DEFAULT NULL COMMENT ''校验产品属性 1校验2.无需校验''', 1); 'tinyint NULL DEFAULT NULL COMMENT ''校验产品属性 1校验2.无需校验''', 1);
CALL Pro_Temp_ColumnWork('auth_user', 'lastUpdatePwdTime', 'datetime', 1); CALL Pro_Temp_ColumnWork('auth_user', 'lastUpdatePwdTime', 'datetime', 1);
call Modify_UNIQUE_index('thr_products_add_di', '`uuid`, `customerId`', 'uniqueUuid', 'BTREE');

Loading…
Cancel
Save