物料导入
parent
7595320380
commit
d13db2705a
|
|
@ -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`")
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue