我的功能是这样的:@Transactionalvoid changeData(CardTO cardTO){ List<CardTO> sameParentCards = cardFactory.getSameParentCards(cardTO.getParentId()); cardTO.setArchived(true); entityManager.merge(cardTO); for(CardTO c: sameParentCards ) { if(!c.getCardId.equals(cardTO.getCardId())) { c.setParentId(cardTO.getParentId()); entityManager.merge(c); break; } } }其中“getSameCards”方法返回父 ID 等于给定卡 ID 的 cardTO 列表。该函数的结果不会将“已存档”字段保存在数据库中,但在循环内所有内容都已正确保存。循环后合并也结果相同!我的错误在哪里?
1 回答
一只萌萌小番薯
TA贡献1795条经验 获得超7个赞
问题是将实体保存在一个跨国函数中后无法检索它们。所以我在合并数据后检索了cardTO,如下所示:
cardTO.setArchived(true);
entityManager.merge(cardTO);
cardTO = cardFactory.getCardTO(cardTO.getId());
添加回答
举报
0/150
提交
取消