zoukankan      html  css  js  c++  java
  • Hibernate session 缓存引发的问题

    1.业务场景:在页面进行点击操作,然后改变数据状态(在改变数据状态之前需要先验证数据的状态)

    List<PartnerLinkItem> partnerLinkItems = partnerLinkItemRepository.findAllByLinkId(id);

    List<Long> partnerIds = Lists.newArrayList();

    for(PartnerLinkItem item : partnerLinkItems){

    Long partnerId = item.getPartnerId();

    item.setStatus(LinkItemStatus.ACTIVATION);

    PartnerLinkAuditItem partnerLinkAuditItem = new PartnerLinkAuditItem();

    partnerLinkAuditItem.setPartnerId(partnerId);

    partnerLinkAuditItem.setId(idService.nextId());

    partnerLinkAuditItem.setShopCodeType(item.getShopCodeType());

    partnerLinkAuditItem.setLinkAuditId(partnerLinkAudit.getId());

    partnerLinkAuditItem.setStatus(LinkAuditItemStatus.NEW);

    partnerLinkAuditItems.add(partnerLinkAuditItem);

    partnerIds.add(item.getPartnerId());

    }

    this.validatePartnerId(partnerLink.getPlatformId(),partnerIds);

    根据上述代码分析,在validatePartnerId之前执行了findAllByLinkId查询数据,然后使用for循环去更改数据状态,此时虽然没有执行save和flush 提交事务。但是在执行validatePartnerId去查询数据库时,hibernate还是会以更改之后的数据为准,也就是说查询的数据状态不是原本的数据状态,而是更改之后的状态。所以此时验证无法通过

    List<PartnerLinkItem> partnerLinkItems = partnerLinkItemRepository.findAllByLinkId(id);

    List<Long> partnerIds = Lists.newArrayList();

    for(PartnerLinkItem item : partnerLinkItems){

    partnerIds.add(item.getPartnerId());

    }

    this.validatePartnerId(partnerLink.getPlatformId(),partnerIds);

    for(PartnerLinkItem item : partnerLinkItems){

    Long partnerId = item.getPartnerId();

    item.setStatus(LinkItemStatus.ACTIVATION);

    PartnerLinkAuditItem partnerLinkAuditItem = new PartnerLinkAuditItem();

    partnerLinkAuditItem.setPartnerId(partnerId);

    partnerLinkAuditItem.setId(idService.nextId());

    partnerLinkAuditItem.setShopCodeType(item.getShopCodeType());

    partnerLinkAuditItem.setLinkAuditId(partnerLinkAudit.getId());

    partnerLinkAuditItem.setStatus(LinkAuditItemStatus.NEW);

    partnerLinkAuditItems.add(partnerLinkAuditItem);

    }

  • 相关阅读:
    jQuery ajax中支持的数据类型
    行内元素与块级元素
    本地连接无法加载远程访问连接管理器服务,错误711
    SQL Server 两种判断表名是否存在且删除的方式
    SQL Server 2008 修改表名
    MySql5.1在Win7下的安装与重装问题的解决
    JavaScript关闭浏览器
    SQL Server 添加一条数据获取自动增长列的几种方法
    获取当前程序运行目录
    字符串的判断与替换
  • 原文地址:https://www.cnblogs.com/ymqj520/p/12309503.html
Copyright © 2011-2022 走看看