当前位置:Gxlcms > 数据库问题 > 7、数据库的并发

7、数据库的并发

时间:2021-07-01 10:21:17 帮助过:2人阅读

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

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

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

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

有两种方案

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

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

7.2、悲观锁

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

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

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

技术分享

7.3、乐观锁

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

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

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

技术分享

如何加锁:

1、创建相应的字段

2、设置Version

Annotation:

技术分享

XML:

技术分享

7、数据库的并发

标签:

人气教程排行