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