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);

}

 

posted on 2020-02-14 20:50  月满清爵  阅读(208)  评论(0编辑  收藏  举报