Commit 368df64d authored by 施翔轲's avatar 施翔轲

校验项目编码是否存在逻辑优化

parent 245b267b
...@@ -17,7 +17,6 @@ import org.springframework.validation.annotation.Validated; ...@@ -17,7 +17,6 @@ import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull; import javax.validation.constraints.NotNull;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
...@@ -42,9 +41,9 @@ public class CbProjectRecordController extends BaseController { ...@@ -42,9 +41,9 @@ public class CbProjectRecordController extends BaseController {
/** /**
* 校验项目编码是否存在 * 校验项目编码是否存在
*/ */
@GetMapping("/checkProjectCodeExist/{projectCode}") @GetMapping("/checkProjectCodeExist")
public R<Boolean> checkProjectCodeExist(@NotBlank(message = "项目编码不能为空") @PathVariable String projectCode) { public R<Boolean> checkProjectCodeExist(@Validated CbCheckProjectCodeExistBo checkBo) {
return R.ok(dProjectService.checkProjectCodeExist(projectCode)); return R.ok(dProjectService.checkProjectCodeExist(checkBo));
} }
/** /**
......
package com.dsk.cscec.domain.bo;
import lombok.Data;
import javax.validation.constraints.NotBlank;
/**
* @author sxk
* @date 2024.03.22
* @time 16:02
*/
@Data
public class CbCheckProjectCodeExistBo {
/**
* 项目ID
*/
private Long projectId;
/**
* IPM项目编码
*/
@NotBlank(message = "项目编码不能为空")
String projectCode;
}
...@@ -4,6 +4,7 @@ import com.baomidou.mybatisplus.extension.service.IService; ...@@ -4,6 +4,7 @@ import com.baomidou.mybatisplus.extension.service.IService;
import com.dsk.common.core.domain.PageQuery; import com.dsk.common.core.domain.PageQuery;
import com.dsk.common.core.page.TableDataInfo; import com.dsk.common.core.page.TableDataInfo;
import com.dsk.cscec.domain.DProject; import com.dsk.cscec.domain.DProject;
import com.dsk.cscec.domain.bo.CbCheckProjectCodeExistBo;
import com.dsk.cscec.domain.bo.CooperateProjectDetailSearchBo; import com.dsk.cscec.domain.bo.CooperateProjectDetailSearchBo;
import com.dsk.cscec.domain.bo.ProjectDetailBo; import com.dsk.cscec.domain.bo.ProjectDetailBo;
import com.dsk.cscec.domain.bo.ProjectSearchBo; import com.dsk.cscec.domain.bo.ProjectSearchBo;
...@@ -57,13 +58,14 @@ public interface IDProjectService extends IService<DProject> { ...@@ -57,13 +58,14 @@ public interface IDProjectService extends IService<DProject> {
/** /**
* 校验项目编码是否存在 * 校验项目编码是否存在
* *
* @param projectCode 项目编码 * @param checkBo 待校验信息
* @return 校验结果 * @return 校验结果
*/ */
Boolean checkProjectCodeExist(String projectCode); Boolean checkProjectCodeExist(CbCheckProjectCodeExistBo checkBo);
/** /**
* 获取工程项目信息 * 获取工程项目信息
*
* @param projectId 项目ID * @param projectId 项目ID
* @return 工程项目信息 * @return 工程项目信息
*/ */
......
...@@ -28,7 +28,6 @@ import lombok.extern.slf4j.Slf4j; ...@@ -28,7 +28,6 @@ import lombok.extern.slf4j.Slf4j;
import org.springframework.aop.framework.AopContext; import org.springframework.aop.framework.AopContext;
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.transaction.support.TransactionTemplate;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.util.ArrayList; import java.util.ArrayList;
...@@ -63,8 +62,6 @@ public class CbProjectRecordServiceImpl extends ServiceImpl<CbProjectRecordMappe ...@@ -63,8 +62,6 @@ public class CbProjectRecordServiceImpl extends ServiceImpl<CbProjectRecordMappe
private ICbCostMeasureService costMeasureService; private ICbCostMeasureService costMeasureService;
@Resource @Resource
private CbDirectExpenseService directExpenseService; private CbDirectExpenseService directExpenseService;
@Resource
private TransactionTemplate transactionTemplate;
/** /**
* 新增项目 * 新增项目
......
...@@ -18,6 +18,7 @@ import com.dsk.cscec.domain.AdvisoryBody; ...@@ -18,6 +18,7 @@ import com.dsk.cscec.domain.AdvisoryBody;
import com.dsk.cscec.domain.AdvisoryBodyProject; import com.dsk.cscec.domain.AdvisoryBodyProject;
import com.dsk.cscec.domain.CbProjectRecord; import com.dsk.cscec.domain.CbProjectRecord;
import com.dsk.cscec.domain.DProject; import com.dsk.cscec.domain.DProject;
import com.dsk.cscec.domain.bo.CbCheckProjectCodeExistBo;
import com.dsk.cscec.domain.bo.CooperateProjectDetailSearchBo; import com.dsk.cscec.domain.bo.CooperateProjectDetailSearchBo;
import com.dsk.cscec.domain.bo.ProjectDetailBo; import com.dsk.cscec.domain.bo.ProjectDetailBo;
import com.dsk.cscec.domain.bo.ProjectSearchBo; import com.dsk.cscec.domain.bo.ProjectSearchBo;
...@@ -256,15 +257,33 @@ public class IDProjectServiceImpl extends ServiceImpl<DProjectMapper, DProject> ...@@ -256,15 +257,33 @@ public class IDProjectServiceImpl extends ServiceImpl<DProjectMapper, DProject>
/** /**
* 校验项目编码是否存在 * 校验项目编码是否存在
* *
* @param projectCode 项目编码 * @param checkBo 待校验信息
* @return 校验结果 * @return 校验结果
*/ */
@Override @Override
public Boolean checkProjectCodeExist(String projectCode) { public Boolean checkProjectCodeExist(CbCheckProjectCodeExistBo checkBo) {
Assert.isFalse(projectRecordMapper.exists(new LambdaQueryWrapper<CbProjectRecord>() Long projectId = checkBo.getProjectId();
.eq(CbProjectRecord::getIpmProjectNo, projectCode)), "项目台账列表中已存在相同IPM编码的项目"); String projectCode = checkBo.getProjectCode();
return baseMapper.exists(new LambdaQueryWrapper<DProject>()
.eq(DProject::getProjectCode, projectCode)); //新增全新项目时,直接校验IPM编码是否重复和是否存在
if (ObjectUtil.isNull(projectId)) {
Assert.isFalse(projectRecordMapper.exists(new LambdaQueryWrapper<CbProjectRecord>()
.eq(CbProjectRecord::getIpmProjectNo, projectCode)), "项目台账列表中已存在相同IPM编码的项目");
return baseMapper.exists(new LambdaQueryWrapper<DProject>()
.eq(DProject::getProjectCode, projectCode));
} else {
//修改项目信息or新增新阶段项目时
CbProjectRecord projectRecord = projectRecordMapper.selectById(projectId);
if (projectCode.equals(projectRecord.getIpmProjectNo())
&& projectRecord.getIsGetProjectDetail()) {
return true;
} else {
Assert.isFalse(projectRecordMapper.exists(new LambdaQueryWrapper<CbProjectRecord>()
.eq(CbProjectRecord::getIpmProjectNo, projectCode)), "项目台账列表中已存在相同IPM编码的项目");
return baseMapper.exists(new LambdaQueryWrapper<DProject>()
.eq(DProject::getProjectCode, projectCode));
}
}
} }
/** /**
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment