From 3534b13391b2a6152d0f91b72fda343b13a947cb Mon Sep 17 00:00:00 2001
From: ludc <ludc@vci-tech.com>
Date: 星期三, 22 一月 2025 15:55:27 +0800
Subject: [PATCH] 分类码段码值管理查询去除null的情况,分类码段生成编码时去除码值为null的情况

---
 Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java |  179 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 179 insertions(+), 0 deletions(-)

diff --git a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java
new file mode 100644
index 0000000..3181924
--- /dev/null
+++ b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java
@@ -0,0 +1,179 @@
+/*
+ *      Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without
+ *  modification, are permitted provided that the following conditions are met:
+ *
+ *  Redistributions of source code must retain the above copyright notice,
+ *  this list of conditions and the following disclaimer.
+ *  Redistributions in binary form must reproduce the above copyright
+ *  notice, this list of conditions and the following disclaimer in the
+ *  documentation and/or other materials provided with the distribution.
+ *  Neither the name of the dreamlu.net developer nor the names of its
+ *  contributors may be used to endorse or promote products derived from
+ *  this software without specific prior written permission.
+ *  Author: Chill 搴勯獮 (smallchill@163.com)
+ */
+package com.vci.ubcs.code.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
+import com.vci.ubcs.code.constant.FrameWorkDefaultValueConstant;
+import com.vci.ubcs.code.entity.CodeClassifyTemplate;
+import com.vci.ubcs.code.entity.CodeClassifyTemplateAttr;
+import com.vci.ubcs.code.entity.CodeSynonym;
+import com.vci.ubcs.code.mapper.CodeSynonymMapper;
+import com.vci.ubcs.code.service.ICodeClassifyTemplateAttrService;
+import com.vci.ubcs.code.service.ICodeSynonymService;
+import com.vci.ubcs.code.vo.pagemodel.CodeClassifyTemplateAttrVO;
+import com.vci.ubcs.code.wrapper.CodeClassifyTemplateAttrWrapper;
+import com.vci.ubcs.starter.enumpack.CodeTableNameEnum;
+import com.vci.ubcs.starter.util.DefaultAttrAssimtUtil;
+import com.vci.ubcs.starter.util.MdmBtmTypeConstant;
+import com.vci.ubcs.starter.util.UBCSCondition;
+import lombok.AllArgsConstructor;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.Func;
+import org.springframework.stereotype.Service;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+/**
+ * 杩戜箟璇嶇淮鎶� 鏈嶅姟瀹炵幇绫�
+ *
+ * @author yuxc
+ * @since 2023-04-04
+ */
+@Service
+@AllArgsConstructor
+public class CodeSynonymServiceImpl extends ServiceImpl<CodeSynonymMapper, CodeSynonym> implements ICodeSynonymService {
+
+	private final CodeSynonymMapper codeSynonymMapper;
+
+	private final ICodeClassifyTemplateAttrService codeClassifyTemplateAttrService;
+
+	/**
+	 * 杩戜箟璇嶇淮鎶� 鏂板
+	 * @param codeSynonym
+	 * @return
+	 */
+	@Override
+	public boolean addSave(CodeSynonym codeSynonym) {
+		if(codeSynonym.getSynonymValue().isEmpty() || codeSynonym.getSourceValue().isEmpty()){
+			throw new ServiceException("婧愬�煎拰杩戜箟璇嶄笉鑳戒负绌�");
+		}
+		DefaultAttrAssimtUtil.addDefaultAttrAssimt(codeSynonym, MdmBtmTypeConstant.CODE_SYNONYM);
+		// 娣诲姞鏃堕粯璁や负缂栬緫涓�
+		codeSynonym.setLcStatus(FrameWorkDefaultValueConstant.FRAMEWORK_RELEASE_RELEASED);
+		return SqlHelper.retBool(codeSynonymMapper.insert(codeSynonym));
+	}
+
+	/**
+	 * 杩戜箟璇嶇淮鎶� 淇敼
+	 * @param codeSynonym
+	 * @return
+	 */
+	@Override
+	public boolean editSave(CodeSynonym codeSynonym) {
+		DefaultAttrAssimtUtil.updateDefaultAttrAssimt(codeSynonym);
+		return SqlHelper.retBool(codeSynonymMapper.updateById(codeSynonym));
+	}
+
+	/**
+	 * 杩戜箟璇嶇姸鎬佸仠鐢ㄥ惎鐢�
+	 * @param map
+	 * @return
+	 */
+	@Override
+	public boolean updateStatus(Map<String, String> map) {
+		if(Func.isEmpty(map.getOrDefault("oid",""))){
+			throw new ServiceException("蹇呬紶鍙傛暟oid涓嶈兘涓虹┖锛�");
+		}
+		if(Func.isEmpty(map.getOrDefault("lcStatus",""))){
+			throw new ServiceException("鐢熷懡鍛ㄦ湡鐘舵�佷笉鑳戒负绌猴紒");
+		}
+		LambdaUpdateWrapper<CodeSynonym> updateWrapper = Wrappers.<CodeSynonym>update()
+			.lambda().eq(CodeSynonym::getOid, map.get("oid"))
+			.set(CodeSynonym::getLcStatus, map.get("lcStatus"));
+		return SqlHelper.retBool(this.codeSynonymMapper.update(null,updateWrapper));
+	}
+
+	/**
+	 * 鍒犻櫎
+	 * @param oids
+	 * @return
+	 */
+	@Override
+	public R deleteDataByIds(String oids) {
+		if(Func.isBlank(oids)){
+			return R.fail("鏈幏鍙栫殑鍙傛暟oid");
+		}
+		List<Long> oidList = Func.toLongList(oids);
+		LambdaQueryWrapper<CodeClassifyTemplateAttr> wrapper = Wrappers.<CodeClassifyTemplateAttr>query().lambda();
+		oidList.stream().forEach(item->{
+			wrapper.or().like(CodeClassifyTemplateAttr::getSysonymRuleOids, item);
+		});
+		List<CodeClassifyTemplateAttr> voList = codeClassifyTemplateAttrService.selectByWrapper(wrapper);
+		if(!voList.isEmpty()){
+			return R.fail("鍒犻櫎鐨勮鍒欎腑瀛樺湪琚紩鐢ㄧ殑杩戜箟璇嶆煡璇㈣鍒欙紒");
+		}
+		return R.status(SqlHelper.retBool(codeSynonymMapper.deleteBatchIds(oidList)));
+	}
+
+	/**
+	 * 鏌ョ湅杩戜箟璇嶆煡璇㈣鍒欎娇鐢ㄨ寖鍥�
+	 * @param oid
+	 * @return
+	 */
+	@Override
+	public List<CodeClassifyTemplateAttrVO> listUseRangeInClsTempAttr(String oid) {
+		MPJLambdaWrapper<CodeClassifyTemplateAttr> mpjLambdaWrapper = new MPJLambdaWrapper<>(CodeClassifyTemplateAttr.class, CodeTableNameEnum.PL_CODE_CLSTEMPATTR.getText())
+			.selectAll(CodeClassifyTemplateAttr.class)
+			.selectAs(CodeClassifyTemplate::getName,CodeClassifyTemplateAttr::getClassifyTemplateOidName)
+			.leftJoin(CodeClassifyTemplate.class,CodeTableNameEnum.PL_CODE_CLSTEMPLATE.getText(),CodeClassifyTemplate::getOid,CodeClassifyTemplateAttr::getClassifyTemplateOid)
+			.like(CodeClassifyTemplateAttr::getSysonymRuleOids, oid);
+		List<CodeClassifyTemplateAttr> voList = codeClassifyTemplateAttrService.selectByWrapper(mpjLambdaWrapper);
+		return CodeClassifyTemplateAttrWrapper.build().listVO(voList);
+	}
+
+	@Override
+	public String selectNameByWrapper(LambdaQueryWrapper<CodeSynonym> wrappers) {
+		List<CodeSynonym> codeSynonymsList = codeSynonymMapper.selectList(wrappers);
+		if(codeSynonymsList.isEmpty()){
+			return "";
+		}
+		StringBuilder res = new StringBuilder();
+		codeSynonymsList.stream().forEach(item->{
+			res.append(item.getName()).append("(").append(item.getId()).append(")").append(",");
+		});
+		return res.toString().replaceAll(",$", "");
+	}
+
+	/**
+	 * 鑾峰彇杩戜箟璇嶆煡璇㈣鍒�
+	 * @return
+	 */
+	@Override
+	public Map<String, List<CodeSynonym>> getCodeSynonymByOids(Map<String, CodeClassifyTemplateAttrVO> sysonymAttrMap) {
+		if(sysonymAttrMap.isEmpty()){
+			return new HashMap<>();
+		}
+		Map<String, List<CodeSynonym>> resMap = new HashMap<>();
+		for (String key : sysonymAttrMap.keySet()) {
+			List<String> oids = Func.toStrList(sysonymAttrMap.get(key).getSysonymRuleOids());
+			List<CodeSynonym> codeSynonyms = codeSynonymMapper.selectBatchIds(oids);
+			resMap.put(key,codeSynonyms);
+		}
+		return resMap;
+	}
+
+}

--
Gitblit v1.9.3