20260529,日常开发-查老数据全量更新闭坑
问题描述
中午休息的时候,问题反馈群里说任务看不到。懒得理他,下午,还是优先看了这个问题。反正,还是老问题,列表查询的时候,有个字段明明应该为空,这样就查不到,偏偏有值,这样列表看不到。无法审核,检测师还在催。
问题解决
列表查询逻辑:待审核,查询审核结果为空的,此处没毛病。
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 ");驳回的时候,有这段代码,明明置空了,但是又单独注释了。不知道原因是什么,不敢贸然打开注释。注释掉肯定有原因
@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的代码,嗨,确实是有更新。问题很可能就出现 在这里。
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来了,确认了说我这里的更新。
本来想,直接设置那个字段,但是他提醒,除了这个字段还会有其他的字段,你都要注意一下。啊?这样不就又耦合(你那有这段逻辑,我这也有)了,解决不了根本问题。
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、多和同事沟通,找定这个点,死磕。
