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/


你可能感兴趣的:(java,Hibernate,面试,乐观锁,悲观锁)