欢迎来到我的博客

怎么实现hibernate悲观锁和乐观锁?

隔离级别的安全控制是整体一个大的方面,而锁机制更加的灵活,它执行的粒度可以很小,可以在一个事务中存在。

Hibernate悲观锁是依靠底层数据库的锁机制实现,在查询query.setLockMode(),

hibernate的加锁模式有:

LockMode.NONE :无锁机制。

LockMode.WRITE :Hibernate在 Insert和 Update记录的时候会自动获取。

LockMode.READ :Hibernate在读取记录的时候会自动获取。

以上这三种锁机制一般由 Hibernate内部使用,如Hibernate为了保证 Update过程中对象不会被外界修改,会在 save 方法实现中自动为目标对象加上 WRITE锁。

LockMode.UPGRADE :利用数据库的 for update 子句加锁。

LockMode. UPGRADE_NOWAIT : Oracle的特定实现,利用 oracle的 for update nowait子句实现加锁。

加锁方法实现:

Criteria.setLockMode

Query.setLockMode

Session.lock

 

悲观锁会带大量的性能开销。乐观锁是Hibernate在内存实现的,提供了3种实现:

1.基于version:读取出数据时,将此版本号一同读出,之后更新时,对此版本号加一

2.基于timestamp:

乐观锁只须在<hibernate-mapping>配置中配置

 

posted @ 2018-10-09 08:20  八千轮回  阅读(445)  评论(0编辑  收藏  举报
人生三从境界:昨夜西风凋碧树,独上高楼,望尽天涯路。 衣带渐宽终不悔,为伊消得人憔悴。 众里寻他千百度,蓦然回首,那人却在灯火阑珊处。