码迷,mamicode.com
首页 > 数据库 > 详细

7、数据库的并发

时间:2015-12-06 21:08:01      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:

7.1、并发修改可能出现的问题

但两个线程同时修改一个对象时,后操作的对象会将前一个操作对象所更新的值还原。

这样就可能存在并发的问题。

如果需要解决并发需要为其增加锁来控制访问的情况

有两种方案

1、悲观锁(基于数据库的机制的锁)

2、乐观锁(基于Hibernate来加载的锁)

7.2、悲观锁

悲观锁是基于数据库来进行控制

当这个对象被上锁之后,只能有一个线程对其进行操作,如果第二个线程要想操作,只能等待

所以悲观锁效率很低(一般不使用)

技术分享

7.3、乐观锁

由于悲观锁的效率不高,hibernate提供内一种乐观锁的机制

其实就是为每一个对象增加一个版本号(等于在数据库中增加一个字段,这个字段由hibernate来维护,不由程序员控制)

原理是:但对象被修改之后会在其版本号上面加1,第二个线程再修改时版本号已经变了,就会抛出异常

技术分享

如何加锁:

1、创建相应的字段

2、设置Version

Annotation:

技术分享

XML:

技术分享

7、数据库的并发

标签:

原文地址:http://www.cnblogs.com/lvjun2015/p/5024298.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!