hibernate事务与并发

Hibernate事务与并发

一、概述

1、hibernate本身没有事务的实现

      hibernate直接使用JDBC连接和JTA(Java Transanction Api)资源, 不添加任何附加锁定行为。

 2、hibernate不锁定内存中的对象

     应用程序按照数据库事务的隔离级别规定的运作,真正对事务的实现和支持都依赖于数据库

3、并发处理

     hibernate提供了乐观锁和悲观锁来进行并发处理,hibernate对乐观锁并发控制提供版本管理,对行级悲观锁定hibernate也提供了辅助的(少量的)Api,它使用了SELECT FOR UPDATE 的sql语法。


二、Session 和事务范围

1、Hibernate的Session是和事务联系在一起的

可以通过Session获取事务的接口,从而进行事务的控制

2、数据库事务应该尽可能的短

这样能降低数据库中的所争用。数据库长事务会阻止应用程序扩展到高的并发负载。

3、反模式:session-per-operation(session每次操作)

在单个线程中,不要因为一次数据库操作,就打开和关闭Session!数据库事务也是如此。也就是说应该禁止自动事务提交。

4、Session-per-request(session每次请求)

最常用的模式是每个请求一个会话。在客户端的请求被发送的服务器端的时候(即hibernate持久化层),一个新的Hibernate Session应该被开启,并执行操作单元中所有的数据库操作,一旦操作完成(同时对客户端的响应也准备就绪),Session被同步关闭。所以服务端要处理请求的时候开启事务,响应发送给客户端之前结束事务,通常使用ServeltFilter来完成。


三、数据库事务声明

1、非托管环境下

应用程序没有托管到J2EE环境中,通常由hibernate自己来负责数据库连接池。开发人员必须手工设置事务声明,即手工启动,提交,或回滚数据库事务。

2、使用JTA

又有两中方式,一是:在hibernate配置里面修改transaction的factory类,从程序里面可以直接使用hibernate的事务API,也就是程序不用变化;二是:直接通过JNDI去查找UserTransaction,然后在直接在程序里面使用JTA的接口来控制事务。


四、乐观并发控制

1、应用程序级别的版本检查

由应用程序自己实现版本检查来确保对话事务的隔离,从数据库访问角度来说是最低效的,不推荐使用。

2、扩展周期的Session和自动化版本


五、悲观锁定

1、通常不需要自己去管理锁定策略

hibernate总是使用数据库的锁定机制,从不在内存中锁定对象。因而用户并不需要花很多精力去担心锁定策略。通常,只要JDBC连接指定一下隔离级别,然后让数据库去搞定一切就够了。

2、类LockMode

类LockMode定义了Hibernate所需的不同的锁定级别

1)、当更新或者插入一行记录的时候,锁定级别自动设置为LockMode.WRITE

2)、当用户显示的使用数据库支持的SQL格式SELECT ..... FOR UPDATE 发送SQL 的时候,定级别设置为LockMode.UPGRADE.

3)、当用户显示的使用Oracle数据库的SQL语句SELECT ..... FOR UPDATE NOWAIT 的时候,锁定级别设置LockMode.UPGRADE_NOWAIT。

4)、当HIbernate 在可重复读或者序列化数据库隔离级别下读取数据的时候,锁定模式自动设置为LockMode.READ.这种模式也可以通过用户显式指定进行设置

5)、LockMode.NONE代表无需锁定。在事务结束时,所有的对象都切换到该模式上来。与Session相关的对象通过调用update()或者saveOrUpdate()脱离该模式。

3、显示的指定锁定模式

1)、调用Session.load()的时候指定锁模式(LockMode)

2)、调用Session.lock()

3)、调用Query.setLockMode()

4、显示指定锁定模式

1)、如果在UPGRADE或者UPGRADE_NOWAIT锁定模式下调用Session.load(),并且要读取的对象尚未被Session载入过,那么对象通过SELECT .... FOR UPDATE 这样的SQL语句被载入。如果为一个对象调用过load()方法时,该对象已经在另一个较少限制的锁定模式下载入了,那么hibernate就对该对象调用lock()方法

2)、如果指定的锁定模式是READ,UPGRADE或UPGRADE_NOWAIT,那么Session.lock()就执行版本号检查。(在 UPGRADE 或UPGRADE_NOWAIT 锁定模式下 ,执行 SELECT ... FOR UPDATE 这样的 SQL 语句。 )

3)、如果数据库不支持用户设置的锁定模式,Hibernate 将使用适当的替代模式(而不是扔出异常) 。这一点可以确保应用程序的可移植性。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值