hibernate悲观锁 乐观锁
1.多个事务并发会出现的错误情况
1)dirtyread脏读-->读了其他事务没有提交的数据
2)nonerepeatableread不可重复读-->在同一个事务中读两次得到不同的结果
3)phantomread幻读-->在同一个事务中读两次得到不同的结果(针对插入和删除)
为了解决事务并发出现的三个问题,我们采用四种事务隔离机制
read-uncommitted、read-committed(oracle默认)、repeatableread(mysql默认)、serializable,考虑效率我们一般采用read-committed,但是这种机制不能解决不可重复读这种情况,故产生悲观锁乐观锁的概念
2.悲观锁乐观锁
为了考虑并发的效率,hibernate设置为readcommited,但这样会导致上面说的“不可重复读”,这样就产生了悲观锁乐观锁的概念
悲观锁-->使用数据库的锁,在读出来的时候就把数据锁起来,效率较低(..forupdate)
乐观锁-->定义一个版本号,每次更新之前先比较一下版本,效率较高(因为它不用锁数据)
相关推荐
王道革 2020-07-05
onlypersevere 2020-06-28
sunysh00 2020-06-25
ztyzly00 2020-05-12
mbcsdn 2020-02-02
kevincheung 2020-01-05
bluetears 2019-12-26
Henryztong 2019-12-21
applex 2019-12-14
chenjiazhu 2019-12-13
wensonlee 2019-12-04
houdaxiami 2019-11-17
tangjianft 2019-11-08
luanjun 2019-10-21
txt 2019-10-23