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

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。