Hibernate事务与批量操作.

今天遇到一个问题,采用左右值来实现树,在单个添加时没有问题,但在批量初始化树时出现左值全部为父节点的右值,右值正常.

name lft rgt
root   1   6
child1 2   3
child2 2   5

正确的应为

name lft rgt
root   1   6
child1 2   3
child2 4   5
跟踪代码时发现方法

save(T t,Long pid)中先get了一下父节点,再后再进行相应的运行,并用hql更新pid所属的父节点实体右值.而因为有缓存的关系,导致每次都是取得缓存中的实体,而hql更新了数据但没有更新缓存(应该).导致父节点的右值每次都是固定值.遂在更新完成后evict()一下,保证下次取的时候取得新值.

新取出的pid所属实体正确了,但结果仍是上面的错误结果,乱尝试了很多方法后.还是没有解决问题,最终想当单个的时候没有问题那就基本逻辑是正确的,那会不会是事务的问题呢.我现在使用的是required后改成required new ,问题解决.

究其原因,可能和事务有关,对于初始化又有前后因为联系的,干脆不配置事务.或者需要就给required new . 在事务中那evict()就必要了.

等有时间再详细研究一下.分析.

走了弯路,其实只需要Session.refresh(实体对象),即可,并可以只要Required事务,保证错误回滚时的正确性.


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值