20260529,日常开发-查老数据全量更新闭坑

问题描述

中午休息的时候,问题反馈群里说任务看不到。懒得理他,下午,还是优先看了这个问题。反正,还是老问题,列表查询的时候,有个字段明明应该为空,这样就查不到,偏偏有值,这样列表看不到。无法审核,检测师还在催。

问题解决

列表查询逻辑:待审核,查询审核结果为空的,此处没毛病。

java 复制代码
else if(vo.getPageType().equals(InsurenceAuditEnum.PageType._待审核.getKey())){
WHERE("B.status not in (10060, 10090, 10091, 10070, 10041, 10049)");
WHERE("A.status = 2 and A.result is null ");

驳回的时候,有这段代码,明明置空了,但是又单独注释了。不知道原因是什么,不敢贸然打开注释。注释掉肯定有原因

java 复制代码
    @Override
    public void clearReceiptorId(Long id, String orderNo) {
        log.info("新版流程-自营审核提交-驳回-清空审核人 id {}, orderNo {}", id, orderNo);
        if (!Check.notNull(id)) {
            log.info("新版流程-自营审核提交-驳回-清空审核人 id is null");
            return;
        }
        InsurenceAudit insurenceAudit = insurenceAuditDao.loadById(InsurenceAudit.class, id);
        if (Objects.isNull(insurenceAudit)) {
            log.info("新版流程-自营审核提交-驳回-清空审核人 insurenceAudit is null");
            return;
        }
        log.info("新版流程-自营审核提交-驳回-清空审核人 更新前 is {}", JSONObject.toJSONString(insurenceAudit));
        insurenceAudit.setStatus(null);
        insurenceAudit.setReceiptorId(null);
        insurenceAudit.setReceiveTime(null);
        insurenceAudit.setUpdateTime(new Date());
//        /**
//         * 新增清空审核结果 否则未处理看不到该订单
//         * QX 20250516 fix
//         */
//        insurenceAudit.setResult(null);
        Integer count = insurenceAuditDao.updateAll(insurenceAudit);
        log.info("新版流程-自营审核提交-驳回-清空审核人 更新成功{}", count);
    }

不敢动,很纠结。然后让,测试同学,在测试环境验证一下,结果没问题。看来,这个注释,是没有你问题的。就让服务组那边查问题,setResult为什么没有置空,他看了他那的代码,也没啥问题,查询到会更新这个字段。

哎,很神奇。我还在反思,不知道哪里的问题,还在找,他一口咬定是我这设置进去的。我看了crm的代码,嗨,确实是有更新。问题很可能就出现 在这里。

java 复制代码
log.info("自营审核检测订单自动分配-有历史驳回信息 直接领单,orderNo:{}", orderNo);
InsurenceAudit query = new InsurenceAudit();
query.setOrderNo(orderNo);
InsurenceAudit queryHist = CRPCService.INSURANCE_AUDIT_SERVICE.queryOneEntity(query);

autoAllotAct(queryHist, orderNo,  history.getOperatorId());


private void autoAllotAct(InsurenceAudit audit, String orderNo, Long receiptorId){
    audit.setReceiptorId(receiptorId);
    audit.setReceiveTime(new Date());
    audit.setStatus(2);
    /**
    * 记录分配动作
    */
    allotNew(audit.getOrderNo(), receiptorId);

    Boolean flag = CRPCService.INSURANCE_AUDIT_SERVICE.updateNotNull(audit);

一开始,我想在更新时,单独设置这个字段未null。无论如何,这个字段都会为空,这样问题就都解决了。

但是,一会,对方拿着dba给的执行的sql来了,确认了说我这里的更新。

本来想,直接设置那个字段,但是他提醒,除了这个字段还会有其他的字段,你都要注意一下。啊?这样不就又耦合(你那有这段逻辑,我这也有)了,解决不了根本问题。

java 复制代码
private void autoAllotAct(InsurenceAudit audit, String orderNo, Long receiptorId){
    /**
     * 记录分配动作
     */
    allotNew(audit.getOrderNo(), receiptorId);

    /**
     * 调整为更新需要更新的字段
     * QX 20260528
     */
    InsurenceAudit updateAudit = new InsurenceAudit();
    updateAudit.setReceiptorId(receiptorId);
    updateAudit.setReceiveTime(new Date());
    updateAudit.setStatus(2);
    updateAudit.setId(audit.getId());
    updateAudit.setUpdateTime(new Date());
    Boolean flag = CRPCService.INSURANCE_AUDIT_SERVICE.updateNotNull(updateAudit);

最后这样,new了一个对象,只更新我需要更新的字段,其他的字段,被更新了呗。而,原来是先查询旧数据,然后全量字段更新,这样就会有主从的问题,嗨,完美。

问题总结

1、需要时间,这问题没有时间,无法解决。

2、每次放假或者休息时间,找来,烦死了,必须解决

3、多和同事沟通,找定这个点,死磕。

相关推荐
nanxun8867 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
用户1563068103519 小时前
Day01 | Java 基础(Java SE)
java
行者全栈架构师11 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师15 小时前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_015 小时前
mac(m5)平台编译openjdk
java
唐青枫2 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
云技纵横2 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二2 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
一个做软件开发的牛马2 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261352 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java