java面试狂魔之hibernate悲观锁和乐观锁

HR:请谈谈Hibernate悲观锁和乐观锁的原理和应用场景?

(ps:虽然现在很多企业都在用mybatis代替hibernate,但hibernate还是有一定地位的,此文仅供吐槽。吐吧。。。。)


业务逻辑的实现过程中,往往需要保证数据访问的排他性。如在金融系统的日终结算

处理中,我们希望针对某个cut-off时间点的数据进行处理,而不希望在结算进行过程中

(可能是几秒种,也可能是几个小时),数据再发生变化。此时,我们就需要通过一些机

制来保证这些数据在某个操作过程中不会被外界修改,这样的机制,在这里,也就是所谓

的“锁”,即给我们选定的目标数据上锁,使其无法被其他程序修改。

hibernate之悲观锁和乐观锁

悲观锁:

1.场景:A和B都想上厕所,但是A先进去了,那么B你只有等等。

2.原理:基于数据库锁机制,并发很安全,但对于长事务而言,这样的数据库开销往往无法承受。(等你一个人处理完,别人都等死了)

乐观锁:

1.场景:操作员A和操作员B都在对同一个银行账户做扣款操作时,先操作的A操作时,更新数据的同时,也会更新表中加的字段数据库版本Version的值(一般都是递增),提交时,会比对version数据版本号,只有大于之前旧数据版本号,才允许操作成功,否则操作驳回。

2.原理:大多数情况是基于外部系统的数据存储逻辑,并发时,都可操作数据,但最后提交未必都成功,即提交更新等操作时基于版本号。但因基于外部应用系统,可能会有脏数据更新到数据库;解决办法即,对加了乐观锁的存储过程,对外部应用系统开发,都可调用,但是不要将存储过程中的表对外开放操作。


如果你没看懂,可以点以下链接,去看吧

http://blog.163.com/ainiyiwannian2046@126/blog/static/4910134020093221132298/


  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值