7、数据库的并发
2015-12-06 20:15
295 查看
7.1、并发修改可能出现的问题
但两个线程同时修改一个对象时,后操作的对象会将前一个操作对象所更新的值还原。
这样就可能存在并发的问题。
如果需要解决并发需要为其增加锁来控制访问的情况
有两种方案
1、悲观锁(基于数据库的机制的锁)
2、乐观锁(基于Hibernate来加载的锁)
7.2、悲观锁
悲观锁是基于数据库来进行控制
当这个对象被上锁之后,只能有一个线程对其进行操作,如果第二个线程要想操作,只能等待
所以悲观锁效率很低(一般不使用)
7.3、乐观锁
由于悲观锁的效率不高,hibernate提供内一种乐观锁的机制
其实就是为每一个对象增加一个版本号(等于在数据库中增加一个字段,这个字段由hibernate来维护,不由程序员控制)
原理是:但对象被修改之后会在其版本号上面加1,第二个线程再修改时版本号已经变了,就会抛出异常
如何加锁:
1、创建相应的字段
2、设置Version
Annotation:
XML:
但两个线程同时修改一个对象时,后操作的对象会将前一个操作对象所更新的值还原。
这样就可能存在并发的问题。
如果需要解决并发需要为其增加锁来控制访问的情况
有两种方案
1、悲观锁(基于数据库的机制的锁)
2、乐观锁(基于Hibernate来加载的锁)
7.2、悲观锁
悲观锁是基于数据库来进行控制
当这个对象被上锁之后,只能有一个线程对其进行操作,如果第二个线程要想操作,只能等待
所以悲观锁效率很低(一般不使用)
7.3、乐观锁
由于悲观锁的效率不高,hibernate提供内一种乐观锁的机制
其实就是为每一个对象增加一个版本号(等于在数据库中增加一个字段,这个字段由hibernate来维护,不由程序员控制)
原理是:但对象被修改之后会在其版本号上面加1,第二个线程再修改时版本号已经变了,就会抛出异常
如何加锁:
1、创建相应的字段
2、设置Version
Annotation:
XML:
相关文章推荐
- mongodb的CursorNotFound异常
- 配置mysql5.5主从服务器(转)
- mysql的root密码重置
- Redis源码分析-内存分配
- 20151206 重新搭建oracle11g单机环境 oracle篇
- 关于Redis数据过期策略
- 数据库——存储过程
- SGA之SQL
- MySQL的启动
- Linux运维 第五阶段(六)mysql高可用(基于corosync,drbd)
- Redis "MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk"问题的解决
- plsql调输入的快捷方式
- Redis高级进阶(二)
- mysql安装及主从
- sqlserver实现树形结构递归查询(无限极分类)
- redis安装后提示权限问题ERR operation not permitted
- PgSQL · 特性分析 · 谈谈checkpoint的调度
- 数据库优化
- 数据库优化
- Redis配置讲解