sgj
2026-03-27 878b6958363308a7d07b7b8197dc19662f3e1198
获取出入库id,逻辑优化调整
已修改3个文件
48 ■■■■ 文件已修改
fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutRecordService.java 31 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
fzzy-igdss-view/src/main/java/com/fzzy/igds/InoutDataPR.java 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
fzzy-igdss-web/src/main/java/com/fzzy/inout/manager/InoutManager.java 11 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutRecordService.java
@@ -244,7 +244,7 @@
        InoutRecord record = new InoutRecord();
        BeanUtils.copyProperties(data, record);
        //保存
        int num = this.addInoutRecord(record);
        int num = this.addInoutRecord(record,true);
        //附件处理
        fileService.saveInoutFiles(data.getFiles(), record.getId(), null, "INOUT");
@@ -262,13 +262,13 @@
     * @param list
     * @return
     */
    public String addInoutRecordList(List<InoutRecord> list) {
    public String addInoutRecordList(List<InoutRecord> list,boolean isCache) {
        if (null == list || list.isEmpty()) {
            return "新增失败";
        }
        for (InoutRecord inoutRecord : list) {
            addInoutRecord(inoutRecord);
            addInoutRecord(inoutRecord,isCache);
        }
        return null;
@@ -280,10 +280,10 @@
     * @param data
     * @return
     */
    public int addInoutRecord(InoutRecord data) {
    public int addInoutRecord(InoutRecord data,boolean isCache) {
        if (StringUtils.isBlank(data.getId())) {
            String id = this.createId(data.getRegisterTime(), data.getCompanyId());
            String id = this.createId(data.getRegisterTime(), data.getCompanyId(),isCache);
            if (Constant.TYPE_IN.equals(data.getType())) {
                data.setId("R_" + id);
            } else if (Constant.TYPE_OUT.equals(data.getType())) {
@@ -595,7 +595,7 @@
     * @param companyId
     * @return
     */
    public String createId(Date registerTime, String companyId) {
    public String createId(Date registerTime, String companyId,boolean isCache) {
        // 时间戳标签
        String timeKey = DateFormatUtils.format(registerTime, "yyyyMMdd");
@@ -603,7 +603,10 @@
        // 从缓存中获取已有的组织编码
        String cacheKey = RedisConst.buildKey(companyId, Constant.CACHE_RECORD_ID);
        String cacheId = (String) redisCache.getCacheObject(cacheKey);
        String cacheId = null;
        if (isCache) {
            cacheId=(String) redisCache.getCacheObject(cacheKey);
        }
        if (null != cacheId && cacheId.indexOf(timeKey) >= 0) {
            String temp = cacheId.substring(cacheId.length() - 4);
@@ -668,7 +671,9 @@
        }
        // 更新缓存
        if(isCache){
        redisCache.setCacheObject(cacheKey, cacheId);
        }
        return cacheId;
    }
@@ -683,15 +688,8 @@
    public boolean checkIdExists(String companyId, String id) {
        QueryWrapper<InoutRecord> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("company_id", companyId);
        queryWrapper.and(wrapper ->
                wrapper.eq("id", id)
                        .or()
                        .eq("id", "R_" + id)
                        .or()
                        .eq("id", "C_" + id)
                        .or()
                        .eq("id", "M_" + id)
        );
        //使用likeleft
        queryWrapper.likeLeft("id", id);
        List<InoutRecord> inoutRecords = inoutRecordMapper.selectList(queryWrapper);
        if( null != inoutRecords && inoutRecords.size() > 0){
            return true;
@@ -716,7 +714,6 @@
        queryWrapper.eq("company_id", companyId);
        queryWrapper.like("id", timeKey);
        queryWrapper.orderByDesc("register_time");
        queryWrapper.orderByDesc("id");
        List<InoutRecord> inoutRecords = inoutRecordMapper.selectList(queryWrapper);
        if (null == inoutRecords || inoutRecords.isEmpty()) {
            return null;
fzzy-igdss-view/src/main/java/com/fzzy/igds/InoutDataPR.java
@@ -25,8 +25,10 @@
import org.apache.commons.lang3.time.DateUtils;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.util.*;
import java.util.Date;
import java.util.List;
/**
 * @Description 出入库详单页面管理
@@ -284,7 +286,7 @@
            }
            //新增数据
            String msg = inoutRecordService.addInoutRecordList(inoutRecords);
            String msg = inoutRecordService.addInoutRecordList(inoutRecords,false);
            if(null == msg){
                return BaseResp.success("导入成功,共计导入" + inoutRecords.size() + "条数据!"  );
fzzy-igdss-web/src/main/java/com/fzzy/inout/manager/InoutManager.java
@@ -15,15 +15,16 @@
import com.fzzy.work.data.WorkStatus;
import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.core.redis.RedisCache;
import lombok.extern.slf4j.Slf4j;
import com.ruoyi.common.utils.StringUtils;
import org.springframework.scheduling.annotation.Async;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.util.*;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
/**
 * @Description 出入库业务处理
@@ -230,7 +231,7 @@
        data.setRegisterUser(ContextUtil.getLoginUserName());
        data.setRegisterTime(new Date());
        num = inoutRecordService.addInoutRecord(data);
        num = inoutRecordService.addInoutRecord(data,true);
        if (num == 0) {
            return new PageResponse<>(RespCodeEnum.CODE_1111.getCode(), "登记失败!", data);