您的位置:首页 > 数据库

7、数据库的并发

2015-12-06 20:15 295 查看
7.1、并发修改可能出现的问题

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

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

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

有两种方案

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

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

7.2、悲观锁

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

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

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





7.3、乐观锁

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

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

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





如何加锁:

1、创建相应的字段

2、设置Version

Annotation:





XML:



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: