Hibernate的事务和并发控制

Hibernate的事务和并发控制

ID:47034393

大小:37.02 KB

页数:13页

时间:2019-07-02

Hibernate的事务和并发控制_第1页
Hibernate的事务和并发控制_第2页
Hibernate的事务和并发控制_第3页
Hibernate的事务和并发控制_第4页
Hibernate的事务和并发控制_第5页
资源描述:

《Hibernate的事务和并发控制》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、Hibernate的事务和并发控制很容易掌握。Hibernate直接使用JDBC连接和JTA资源,不添加任何附加锁定行为。我们强烈推荐你花点时间了解JDBC编程,ANSISQL查询语言和你使用的数据库系统的事务隔离规范。Hibernate只添加自动版本管理,而不会锁定内存中的对象,也不会改变数据库事务的隔离级别。基本上,使用Hibernate就好像直接使用JDBC(或者JTA/CMT)来访问你的数据库资源。 除了自动版本管理,针对行级悲观锁定,Hibernate也提供了辅助的API,它使用了SELECTFORUPDATE的SQL语法。本章后面会

2、讨论这个API。我们从Configuration层、SessionFactory层,和Session层开始讨论Hibernate的并行控制、数据库事务和应用程序的长事务。12.1.Session和事务范围(transactionscopes)一个SessionFactory对象的创建代价很昂贵,它是线程安全的对象,它被设计成可以为所有的应用程序线程所共享。它只创建一次,通常是在应用程序启动的时候,由一个Configuraion的实例来创建。一个Session的对象是轻型的,非线程安全的,对于单个业务进程,单个的工作单元而言,它只被使用一次,然后

3、就丢弃。只有在需要的时候,Session才会获取一个JDBC的Connection(或一个Datasource)对象。所以你可以放心的打开和关闭Session,甚至当你并不确定一个特定的请求是否需要数据访问时,你也可以这样做。(一旦你实现下面提到的使用了请求拦截的模式,这就变得很重要了。此外我们还要考虑数据库事务。数据库事务应该尽可能的短,降低数据库锁定造成的资源争用。数据库长事务会导致你的应用程序无法扩展到高的并发负载。一个操作单元(Unitofwork)的范围是多大?单个的HibernateSession能跨越多个数据库事务吗?还是一个Se

4、ssion的作用范围对应一个数据库事务的范围?应该何时打开Session,何时关闭Session?,你又如何划分数据库事务的边界呢?12.1.1.操作单元(Unitofwork)首先,别再用session-per-operation这种反模式了,也就是说,在单个线程中,不要因为一次简单的数据库调用,就打开和关闭一次Session!数据库事务也是如此。应用程序中的数据库调用是按照计划好的次序,分组为原子的操作单元。(注意,这也意味着,应用程序中,在单个的SQL语句发送之后,自动事务提交(auto-commit)模式失效了。这种模式专门为SQL控制

5、台操作设计的。Hibernate禁止立即自动事务提交模式,或者期望应用服务器禁止立即自动事务提交模式。)在多用户的client/server应用程序中,最常用的模式是每个请求一个会话(session-per-request)。在这种模式下,来自客户端的请求被发送到服务器端(即Hibernate持久化层运行的地方),一个新的HibernateSession被打开,并且执行这个操作单元中所有的数据库操作。一旦操作完成(同时发送到客户端的响应也准备就绪),session被同步,然后关闭。你也可以使用单个数据库事务来处理客户端请求,在你打开Sessio

6、n之后启动事务,在你关闭Session之前提交事务。会话和请求之间的关系是一对一的关系,这种模式对于大多数应用程序来说是很棒的。真正的挑战在于如何去实现这种模式:不仅Session和事务必须被正确的开始和结束,而且他们也必须能被数据访问操作访问。用拦截器来实现操作单元的划分,该拦截器在客户端请求达到服务器端的时候开始,在服务器端发送响应(即,ServletFilter)之前结束。我们推荐使用一个ThreadLocal变量,把Session绑定到处理客户端请求的线程上去。这种方式可以让运行在该线程上的所有程序代码轻松的访问Session(就像访问

7、一个静态变量那样)。你也可以在一个ThreadLocal变量中保持事务上下文环境,不过这依赖于你所选择的数据库事务划分机制。这种实现模式被称之为ThreadLocalSession和OpenSessioninView。你可以很容易的扩展本文前面章节展示的HibernateUtil辅助类来实现这种模式。当然,你必须找到一种实现拦截器的方法,并且可以把拦截器集成到你的应用环境中。请参考Hibernate网站上面的提示和例子。12.1.2.应用程序事务(Applicationtransactions)session-per-request模式不仅仅是

8、一个可以用来设计操作单元的有用概念。很多业务处理流程都需要一系列完整的和用户之间的交互,即用户对数据库的交叉访问。在基于web的应用和企业应用中,跨用

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。