From e29f147aab5b0b0b794d611b522b67b94423e3cf Mon Sep 17 00:00:00 2001
From: Fixiaobai <fixiaobai@163.com>
Date: 星期四, 07 九月 2023 17:56:57 +0800
Subject: [PATCH] 修改bug
---
standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java | 93 ++++++++++++++++++++++++++++++----------------
1 files changed, 60 insertions(+), 33 deletions(-)
diff --git a/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java b/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java
index b82da28..32a0349 100644
--- a/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java
+++ b/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java
@@ -1,24 +1,21 @@
package com.yuanchu.limslaboratory.service.impl;
-import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
-import com.baomidou.mybatisplus.core.metadata.IPage;
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.yuanchu.limslaboratory.pojo.Product;
import com.yuanchu.limslaboratory.mapper.ProductMapper;
+import com.yuanchu.limslaboratory.pojo.dto.StandardProductAddDto;
import com.yuanchu.limslaboratory.service.ProductService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.yuanchu.limslaboratory.utils.MyUtil;
-import org.springframework.beans.factory.annotation.Autowired;
-import com.yuanchu.limslaboratory.service.UserService;
import org.springframework.stereotype.Service;
-import org.springframework.util.ObjectUtils;
+import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
-import java.util.ArrayList;
+import java.util.Date;
import java.util.List;
import java.util.Map;
-import java.util.Objects;
+
/**
* <p>
@@ -34,9 +31,10 @@
@Resource
private ProductMapper productMapper;
+
@Override
public void deleteProductInformation(List<Integer> SpecificationsId) {
- for (Integer materialId : SpecificationsId){
+ for (Integer materialId : SpecificationsId) {
LambdaUpdateWrapper<Product> wrapper = new LambdaUpdateWrapper<>();
wrapper.eq(Product::getSpecifications_id, materialId);
wrapper.set(Product::getState, 0);
@@ -44,36 +42,65 @@
}
}
+ //灞曠ず璇ュ瀷鍙蜂笅鐨勬楠岄」鐩姹�-->閫夋嫨鐗堟湰
@Override
- public IPage<Map<String, Object>> pageProductInformation(String productCodeOrName, Integer specificationsId, Page<Objects> page) {
- IPage<Map<String, Object>> iPage = productMapper.pageProductInformation(productCodeOrName, specificationsId, page);
- List<Map<String, Object>> maps = iPage.getRecords();
- maps.forEach(map -> {
- int num = Integer.parseInt(map.get("num").toString());
- boolean children = false;
- if (num > 1){
- children = true;
- } else {
- Map<String, Object> product = productMapper.selectOneChildren(map.get("father"));
- map.putAll(product);
- }
- map.put("children", children);
- map.remove("num");
- });
- return iPage;
+ public List<Integer> chooseVersion(Integer specificationsId) {
+ return productMapper.chooseVersion(specificationsId);
+ }
+
+ //灞曠ず璇ュ瀷鍙蜂笅鐨勬楠岄」鐩姹�
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public List<Map<String, Object>> pageProductInformation(Integer specificationsId, Integer version) {
+ return productMapper.pageProductInformation(specificationsId, version);
+ }
+
+ //濉啓鏍囧噯鍊间笌鍐呮帶鍊�,榧犳爣绉诲紑淇濆瓨
+ @Override
+ public Integer write(Integer id, String required, String internal) {
+ Product product = new Product();
+ product.setId(id);
+ product.setRequired(required);
+ product.setInternal(internal);
+ MyUtil.PrintLog(product.toString());
+ return productMapper.updateById(product);
}
@Override
- public List<Map<String, Object>> pageFatherNameProductInformation(String fatherName) {
- LambdaQueryWrapper<Product> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(Product::getFather, fatherName);
- wrapper.select(Product::getId, Product::getName, Product::getUnit, Product::getRequired, Product::getInternal);
- return productMapper.selectMaps(wrapper);
+ public void deleteList(String ids) {
+ productMapper.deleteList(ids);
}
- //閫氳繃椤圭洰鍚嶆煡璇㈤」鐩殑璇曢獙鏂规硶
+ //娣诲姞鍚屼竴涓瀷鍙风殑鍏朵粬鐗堟湰
@Override
- public List<Map> selectInstrumentByProname(String name) {
- return productMapper.selectInstrumentByProname(name);
+ public Integer addVersion(Integer specificationsId, Integer version) {
+ List<Product> productList = productMapper.selectList(Wrappers.<Product>query()
+ .eq("specifications_id", specificationsId)
+ .eq("version", version));
+ for (Product product : productList) {
+ product.setId(null);
+ product.setVersion(productMapper.chooseVersion(specificationsId).get(0) + 1);
+ product.setSpecifications_id(specificationsId);
+ }
+ saveBatch(productList);
+ return productList.get(0).getVersion();
}
+
+ //鏌ヨ璇ュ瀷鍙蜂笅鐨勬墍鏈夎瘯楠岄」鐩�(鐖剁被)
+ @Override
+ public List<Map<String, Object>> chooseProject(Integer modelId) {
+ return productMapper.chooseProject(modelId);
+ }
+
+ @Override
+ public String addProduct(StandardProductAddDto dto) {
+ int i = productMapper.addProduct(new Product(
+ dto.getName(), dto.getFather(),
+ dto.getUnit(), new Date(), new Date(),
+ Integer.parseInt(dto.getVersion()), dto.getSpecificationId()));
+ if(i>0) return "娣诲姞鎴愬姛锛�";
+ return "娣诲姞澶辫触";
+ }
+
+
}
--
Gitblit v1.9.3