hibernate锁

hibernate 锁机制

我是研究僧i 提交于 2020-02-29 02:58:00
Hibernate 悲观锁,乐观锁 1.悲观锁 它指的是对数据被外界修改持保守态度。假定任何时刻存取数据时,都可能有另一个客户也正在存取同一笔数据,为了保持数据被操作的一致性,于是对数据采取了数据库层次的锁定状态,依靠数据库提供的锁机制来实现。 基于jdbc实现的数据库加锁如下: select * from account where name="Erica" for update 在更新的过程中,数据库处于加锁状态,任何其他的针对本条数据的操作都将被延迟。本次事务提交后解锁。 而hibernate悲观锁的具体实现如下: String sql="查询语句"; Query query=session.createQuery(sql); query.setLockMode("对象",LockModel.UPGRADE); 说到这里,就提到了hibernate的加锁模式: LockMode.NONE:无锁机制。 LockMode.WRITE:Hibernate在Insert和Update记录的时候会自动获取。 LockMode.READ:Hibernate在读取记录的时候会自动获取。 这三种加锁模式是供hibernate内部使用的,与数据库加锁无关: LockMode.UPGRADE:利用数据库的for update字句加锁。 在这里我们要注意的是:只有在查询开始之前