Hibernate乐观锁的实现原理剖析与使用乐观锁时的注意点 - 编程入门网
Hibernate乐观锁的实现原理剖析与使用乐观锁时的注意点时间:2011-07-29Hibernate支持乐观锁。当多个事务同时对数据库表中的同一条数据操作时,如果没有加锁机制的话,就会产生脏数据(duty data)。Hibernate有2种机制可以解决这个问题:乐观锁和悲观锁。这里我们只讨论乐观锁。 Hibernate乐观锁,能自动检测多个事务对同一条数据进行的操作,并根据先胜原则,提交第一个事务,其他的事务提交时则抛出org.hibernate.StaleObjectStateException异常。 Hibernate乐观锁是怎么做到的呢? 我们先从Hibernate乐观锁的实现说起。要实现Hibenate乐观锁,我们首先要在数据库表里增加一个版本控制字段,字段名随意,比如就叫version,对应hibernate类型只能为 long,integer,short,timestamp,calendar,也就是只能为数字或timestamp类型。然后在hibernate mapping里作如下类似定义:
告诉Hibernate version作为版本控制用,交由它管理。 当然在entity class里也需要给version加上定义,定义的方法跟其他字段完全一样。 private Integer version; … // setVersion() && getVersion(Integer) Hibernate乐观锁的的使用:
在事务2提交时,因为它提交的数据比事务1提交后的数据旧,所以hibernate会抛出一个org.hibernate.StaleObjectStateException异常。 回到前面的问题,Hibernate怎么知道事务2提交的数据比事务1提交后的数据旧呢? 因为MyEntity有个version版本控制字段。 回头看看上面的源代码中的: MyEntity et1 = session1.load(MyEntity.class, id); MyEntity et2 = session2.load(MyEntity.class, id); 这里,et1.version==et2.version,比如此时version=1, 当事务1提交后,该数据的版本控制字段version=version+1=2,而事务2提交时version=1<2所以Hibernate认为事务2提交的数据为过时数据,抛出异常。 这就是Hibernate乐观锁的原理机制。 我们已经知道了Hibernate乐观锁是根据version的值来判断数据是否过时,也就是说,在向数据库update某数据时,必须保证该entity 里的version字段被正确地设置为update之前的值,否则hibernate乐观锁机制将无法根据version作出正确的判断。 在我们的WEB应用中,尤其应该注意这个问题。 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |