Hibernate学习:悲观锁
一:测试程序
二:代码分析
(1)debug方法testPessimisticLock,
Account a = (Account) session.load(Account.class, 1,LockMode.UPGRADE);
session.getTransaction().commit();
在session提交的这一行,加上断点。
(2)执行方法testOperate
会发现,改方法并没有成功修改数据
(3)将testPessimisticLock断点走完
(4)testOperate才会成功执行。
三:知识点
LockMode.UPGRADE通常我们就同这个参数,加悲观锁
Account a = (Account) session.load(Account.class, 1,LockMode.UPGRADE);
查看执行的sql语句,就会发现sql语句后面出现了for update
select
account0_.id as id0_0_,
account0_.balance as balance0_0_
from
Account account0_
where
account0_.id=? for update
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。