物料导入

main
HUOJIN\92525 2024-07-05 18:45:57 +08:00
parent 7595320380
commit d13db2705a
5 changed files with 199 additions and 110 deletions

View File

@ -144,7 +144,7 @@ public class Item extends BaseEntity implements Serializable {
private Long sourceId; private Long sourceId;
@Column(name = "`extend_d1`") @Column(name = "`extend_d1`")
@ApiModelProperty(value = "默认容器装载数") @ApiModelProperty(value = "单台用量")
private Double extendD1=0d; private Double extendD1=0d;
@Column(name = "`extend_d2`") @Column(name = "`extend_d2`")

View File

@ -21,6 +21,7 @@ import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Query; import org.springframework.data.jpa.repository.Query;
import java.util.List; import java.util.List;
import java.util.Set;
/** /**
* @author houjianlan * @author houjianlan
@ -28,6 +29,9 @@ import java.util.List;
* @date 2023-08-16 * @date 2023-08-16
**/ **/
public interface ItemRepository extends JpaRepository<Item, Long>, JpaSpecificationExecutor<Item> { public interface ItemRepository extends JpaRepository<Item, Long>, JpaSpecificationExecutor<Item> {
@Query(value = "FROM Item i WHERE i.code = ?1 ") @Query(value = "from Item i where i.code = :code ")
Item findByItemCode(String code); Item findByItemCode(String code);
@Query(value = "from Item i where i.code in :itemCodes ")
List<Item> findByCodes(Set itemCodes);
} }

View File

@ -20,7 +20,9 @@ import cn.hutool.poi.excel.ExcelReader;
import cn.hutool.poi.excel.ExcelUtil; import cn.hutool.poi.excel.ExcelUtil;
import com.youchain.annotation.AnonymousAccess; import com.youchain.annotation.AnonymousAccess;
import com.youchain.annotation.Log; import com.youchain.annotation.Log;
import com.youchain.basicdata.domain.Area;
import com.youchain.basicdata.domain.Item; import com.youchain.basicdata.domain.Item;
import com.youchain.basicdata.domain.Point;
import com.youchain.basicdata.domain.StockType; import com.youchain.basicdata.domain.StockType;
import com.youchain.basicdata.service.ItemService; import com.youchain.basicdata.service.ItemService;
import com.youchain.basicdata.service.StockTypeService; import com.youchain.basicdata.service.StockTypeService;
@ -28,15 +30,17 @@ import com.youchain.basicdata.service.dto.ItemDto;
import com.youchain.basicdata.service.dto.ItemQueryCriteria; import com.youchain.basicdata.service.dto.ItemQueryCriteria;
import com.youchain.basicdata.service.dto.StockTypeQueryCriteria; import com.youchain.basicdata.service.dto.StockTypeQueryCriteria;
import com.youchain.config.FileProperties; import com.youchain.config.FileProperties;
import com.youchain.config.thread.ThreadPoolExecutorUtil;
import com.youchain.exception.handler.ApiError; import com.youchain.exception.handler.ApiError;
import com.youchain.exception.handler.ApiResult;
import com.youchain.modules.system.domain.Dept;
import com.youchain.modules.system.domain.DictDetail; import com.youchain.modules.system.domain.DictDetail;
import com.youchain.modules.system.service.DictDetailService; import com.youchain.modules.system.service.DictDetailService;
import com.youchain.modules.system.service.DictService; import com.youchain.modules.system.service.DictService;
import com.youchain.modules.system.service.dto.DictDetailDto; import com.youchain.modules.system.service.dto.DictDetailDto;
import com.youchain.modules.system.service.dto.DictDto; import com.youchain.modules.system.service.dto.DictDto;
import com.youchain.modules.system.service.dto.DictQueryCriteria; import com.youchain.modules.system.service.dto.DictQueryCriteria;
import com.youchain.utils.FileUtil; import com.youchain.utils.*;
import com.youchain.utils.UserUtils;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.data.domain.Pageable; import org.springframework.data.domain.Pageable;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
@ -50,16 +54,19 @@ import org.springframework.web.multipart.MultipartFile;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.HashMap; import java.util.*;
import java.util.List; import java.util.concurrent.CompletableFuture;
import java.util.Map; import java.util.concurrent.ExecutorService;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.transaction.Transactional; import javax.transaction.Transactional;
import static org.springframework.http.HttpStatus.BAD_REQUEST;
import static org.springframework.http.HttpStatus.OK;
/** /**
* @website https://eladmin.vip
* @author houjianlan * @author houjianlan
* @website https://eladmin.vip
* @date 2023-08-16 * @date 2023-08-16
**/ **/
@RestController @RestController
@ -71,8 +78,7 @@ public class ItemController {
private final ItemService itemService; private final ItemService itemService;
private final FileProperties properties; private final FileProperties properties;
private final StockTypeService stockTypeService;
private final DictDetailService dictDetailService;
@Log("导出数据") @Log("导出数据")
@ApiOperation("导出数据") @ApiOperation("导出数据")
@ -105,67 +111,19 @@ public class ItemController {
} }
@PostMapping(value = "/import_data") @PostMapping(value = "/import_data")
@Log("导入物料")
@ApiOperation("导入物料") @ApiOperation("导入物料")
@Transactional @PreAuthorize("@el.check('point:importPoint')")
@AnonymousAccess public ResponseEntity<Object> importItem(@RequestParam("file") MultipartFile multipartFile) {
public ResponseEntity<Object> createSysAppUpdate( @RequestParam("file") MultipartFile multipartFile) { //编码、名称、物料类型
FileUtil.checkSize(properties.getMaxSize(), multipartFile.getSize());
String suffix = FileUtil.getExtensionName(multipartFile.getOriginalFilename());
String type = FileUtil.getFileType(suffix);
log.error("--" + properties.getPath().getPath() + type + File.separator);
File file = FileUtil.upload(multipartFile, properties.getPath().getPath() + type + File.separator);
log.error("--" + file.getPath());
Map<String, StockType> map_stock = stockTypeService.queryAll();
DictQueryCriteria dictQueryCriteria=new DictQueryCriteria();
dictQueryCriteria.setBlurry("item_unit");
Map<String, DictDetail> map_dic = dictDetailService.getDictDetailByName("item_unit");
DictQueryCriteria itemTypeDc=new DictQueryCriteria();
itemTypeDc.setBlurry("item_type");
Map<String, DictDetail> item_type_dic = dictDetailService.getDictDetailByName("item_type");
ExcelReader reader = ExcelUtil.getReader(file);
int i=0;
int edit_len=0;
int new_len=0;
try { try {
List<Map<String, Object>> readAll = reader.readAll(); String result = itemService.impoertItem(multipartFile);
for ( i = 0; i < readAll.size(); i++) { return successRequest(result);
Item item = new Item();
String code=readAll.get(i).get("物料代码").toString().trim();
item.setCode(code);
item.setName("" + readAll.get(i).get("物料名称"));
//容器类型
String unit=readAll.get(i).get("单位")+"";
item.setUnit(map_dic.get(unit).getValue());
String packNumber=readAll.get(i).get("默认容器装载数").toString().trim();
item.setPackNumber(Integer.parseInt(packNumber));
String itemType=readAll.get(i).get("物料类型")+"";
item.setGoodType(item_type_dic.get(itemType).getValue());
item.setLength(Double.parseDouble("" + readAll.get(i).get("长")));
item.setWidth(Double.parseDouble("" + readAll.get(i).get("宽")));
item.setHeight(Double.parseDouble("" + readAll.get(i).get("高")));
ItemQueryCriteria itemQueryCriteria=new ItemQueryCriteria();
itemQueryCriteria.setCode(code);
List<ItemDto> itemDto_list=itemService.queryAll(itemQueryCriteria);
if(itemDto_list.size()<=0){
new_len++;
log.error("不存在--" + readAll.get(i).get("编码")+"--");
itemService.create(item);
}else{
edit_len++;
log.error("存在--" + readAll.get(i).get("编码")+"--");
item.setId(itemDto_list.get(0).getId());
itemService.update(item);
}
}
} catch (Exception e) { } catch (Exception e) {
ApiError apiError = ApiError.errorJosn(HttpStatus.BAD_REQUEST.value(), "导入异常---第"+(i+1)+"行:"+e.toString()); return badRequest("导入失败:" + e.getMessage());
return new ResponseEntity(apiError, HttpStatus.valueOf(apiError.getStatus())); }
} }
ApiError apiError = ApiError.errorJosn(HttpStatus.OK.value(), "导入成功:"+(i)+"行 新增("+new_len+")修改("+edit_len+")");
return new ResponseEntity(apiError, HttpStatus.valueOf(apiError.getStatus()));
}
@PutMapping @PutMapping
@Log("修改item") @Log("修改item")
@ -184,4 +142,12 @@ public class ItemController {
itemService.deleteAll(ids); itemService.deleteAll(ids);
return new ResponseEntity<>(HttpStatus.OK); return new ResponseEntity<>(HttpStatus.OK);
} }
private ResponseEntity<Object> badRequest(String message) {
return new ResponseEntity<>(message, HttpStatus.BAD_REQUEST);
}
private ResponseEntity<Object> successRequest(Object object) {
return new ResponseEntity<>(object, HttpStatus.OK);
}
} }

View File

@ -28,18 +28,20 @@ import org.springframework.web.multipart.MultipartFile;
import java.util.Map; import java.util.Map;
import java.util.List; import java.util.List;
import java.io.IOException; import java.io.IOException;
import java.util.Set;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
/** /**
* @author houjianlan
* @website https://eladmin.vip * @website https://eladmin.vip
* @description * @description
* @author houjianlan
* @date 2023-08-07 * @date 2023-08-07
**/ **/
public interface ItemService { public interface ItemService {
/** /**
* *
*
* @param criteria * @param criteria
* @param pageable * @param pageable
* @return Map<String, Object> * @return Map<String, Object>
@ -48,6 +50,7 @@ public interface ItemService {
/** /**
* *
*
* @param criteria * @param criteria
* @return List<ItemDto> * @return List<ItemDto>
*/ */
@ -55,6 +58,7 @@ public interface ItemService {
/** /**
* ID * ID
*
* @param id ID * @param id ID
* @return ItemDto * @return ItemDto
*/ */
@ -62,6 +66,7 @@ public interface ItemService {
/** /**
* ID * ID
*
* @param id ID * @param id ID
* @return ItemDto * @return ItemDto
*/ */
@ -71,27 +76,30 @@ public interface ItemService {
/** /**
* *
*
* @param resources / * @param resources /
* @return ItemDto * @return ItemDto
*/ */
ItemDto create(Item resources); ItemDto create(Item resources);
/** /**
* *
*
* @param resources / * @param resources /
*/ */
void update(Item resources); void update(Item resources);
/** /**
* *
*
* @param ids / * @param ids /
*/ */
void deleteAll(Long[] ids); void deleteAll(Long[] ids);
/** /**
* *
*
* @param all * @param all
* @param response / * @param response /
* @throws IOException / * @throws IOException /
@ -100,6 +108,7 @@ public interface ItemService {
/** /**
* dto * dto
*
* @param itemDto * @param itemDto
* @return * @return
*/ */
@ -107,9 +116,24 @@ public interface ItemService {
/** /**
* *
*
* @param itemCode * @param itemCode
* @return * @return
*/ */
Item existItem(String itemCode); Item existItem(String itemCode);
/**
*
*
* @param itemCodes
* @return
*/
Map<String, Item> findByCodes(Set itemCodes);
/**
*
* @param multipartFile
*/
String impoertItem(MultipartFile multipartFile);
} }

View File

@ -15,13 +15,16 @@
*/ */
package com.youchain.basicdata.service.impl; package com.youchain.basicdata.service.impl;
import cn.hutool.poi.excel.ExcelReader;
import cn.hutool.poi.excel.ExcelUtil;
import com.youchain.basicdata.domain.Area;
import com.youchain.basicdata.domain.Item; import com.youchain.basicdata.domain.Item;
import com.youchain.basicdata.domain.Point; import com.youchain.basicdata.domain.Point;
import com.youchain.basicdata.service.dto.ItemSmallDto; import com.youchain.basicdata.service.dto.ItemSmallDto;
import com.youchain.utils.FileUtil; import com.youchain.config.FileProperties;
import com.youchain.utils.PageUtil; import com.youchain.config.thread.ThreadPoolExecutorUtil;
import com.youchain.utils.QueryHelp; import com.youchain.modules.system.domain.Dept;
import com.youchain.utils.ValidationUtil; import com.youchain.utils.*;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import com.youchain.basicdata.repository.ItemRepository; import com.youchain.basicdata.repository.ItemRepository;
import com.youchain.basicdata.service.ItemService; import com.youchain.basicdata.service.ItemService;
@ -33,18 +36,17 @@ import org.springframework.transaction.annotation.Transactional;
import org.springframework.data.domain.Page; import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable; import org.springframework.data.domain.Pageable;
import java.util.List; import java.io.File;
import java.util.Map; import java.util.*;
import java.io.IOException; import java.io.IOException;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutorService;
import javax.persistence.EntityManager; import javax.persistence.EntityManager;
import javax.persistence.Query; import javax.persistence.Query;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import org.springframework.data.domain.Example; import org.springframework.data.domain.Example;
import org.springframework.web.multipart.MultipartFile;
import java.util.Optional;
/** /**
* @author houjianlan * @author houjianlan
@ -59,6 +61,8 @@ public class ItemServiceImpl implements ItemService {
private final ItemRepository itemRepository; private final ItemRepository itemRepository;
private final ItemMapper itemMapper; private final ItemMapper itemMapper;
private final EntityManager entityMapper; private final EntityManager entityMapper;
private final FileProperties properties;
private final BatchCreateOrUpdate batchCreateOrUpdate;
@Override @Override
public Map<String, Object> queryAll(ItemQueryCriteria criteria, Pageable pageable) { public Map<String, Object> queryAll(ItemQueryCriteria criteria, Pageable pageable) {
@ -175,4 +179,95 @@ public class ItemServiceImpl implements ItemService {
return item.isPresent() ? item.get() : null; return item.isPresent() ? item.get() : null;
} }
@Override
public Map<String, Item> findByCodes(Set itemCodes) {
List<Item> items = itemRepository.findByCodes(itemCodes);
Map<String, Item> itemMap = new HashMap<>();
for (Item item : items) {
itemMap.put(item.getCode(), item);
}
return itemMap;
}
@Override
@Transactional(rollbackFor = Exception.class)
public String impoertItem(MultipartFile multipartFile) {
//编码、名称、物料类型
FileUtil.checkSize(properties.getMaxSize(), multipartFile.getSize());
String suffix = FileUtil.getExtensionName(multipartFile.getOriginalFilename());
String type = FileUtil.getFileType(suffix);
File file = FileUtil.upload(multipartFile, properties.getPath().getPath() + type + File.separator);
Dept dept = UserUtils.getDept();
ExcelReader reader = ExcelUtil.getReader(file);
List<Map<String, Object>> readAll = reader.readAll();
Set<String> itemCodes = new HashSet<>();//物料集合
for (Map<String, Object> record : readAll) {
String itemCode = record.get("编码").toString().trim();
if (!StringUtils.isEmpty(itemCode)) {
itemCodes.add(itemCode);
}
}
//获取已存在的物料
Map<String, Item> existingPoint = findByCodes(itemCodes);
List<Item> itemsToCreate = new ArrayList<>();//新增物料集合
List<Item> itemsToUpdate = new ArrayList<>();//修改物料集合
for (Map<String, Object> record : readAll) {
String itemCode = record.get("编码").toString().trim();
//判断是否已存在点位
if (existingPoint.containsKey(itemCode)) {
Item item = existingPoint.get(itemCode);
//更新点位
itemsToUpdate.add(updateItems(item, dept, record));
} else {
//新增点位
itemsToCreate.add(createItem(dept, record));
}
}
//异步处理
ExecutorService executor = ThreadPoolExecutorUtil.getPoll("item-import-job");
CompletableFuture<Void> createFuture = CompletableFuture.runAsync(() -> {
//批量新增物料
if (!itemsToCreate.isEmpty()) {
batchCreateOrUpdate.batchCreate(itemsToCreate);
}
}, executor);
CompletableFuture<Void> updateFuture = CompletableFuture.runAsync(() -> {
//批量更新物料
if (!itemsToUpdate.isEmpty()) {
batchCreateOrUpdate.batchUpdate(itemsToUpdate);
}
}, executor);
// 等待所有操作完成
CompletableFuture.allOf(createFuture, updateFuture).join();
executor.shutdown();//关闭线程池
return ("导入成功:" + " 新增(" + itemsToCreate.size() + ")修改(" + itemsToUpdate.size() + ")");
}
private Item updateItems(Item item, Dept dept, Map<String, Object> record) {
item.setDept(dept);
item.setName(record.get("名称").toString().trim());
item.setExtendD1(record.get("单台用量") == null ? 0 : Double.parseDouble(record.get("单台用量").toString()));
item.setUnit(record.get("单位").toString().trim());
item.setGoodType(record.get("物料类型") == null ? "" : record.get("物料类型").toString().trim());
return item;
}
private Item createItem(Dept dept, Map<String, Object> record) {
Item item = new Item();
item.setCode(record.get("编码").toString().trim());
item.setName(record.get("名称").toString().trim());
item.setExtendD1(record.get("单台用量") == null ? 0 : Double.parseDouble(record.get("单台用量").toString()));
item.setUnit(record.get("单位").toString().trim());
item.setGoodType(record.get("物料类型") == null ? "" : record.get("物料类型").toString().trim());
item.setDept(dept);
item.setEnabled(true);
return item;
}
} }