- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Java EE实用教程 第11章 Hibernate的高级特性 11.1 Hibernate的事务管理 11.2 Hibernate的并发 11.3 Hibernate的拦截器 11.1 Hibernate的事务管理 11.1.1 事务的概念 事务有4个重要特性: ? 原子性:即作为一个事务,它是一个不可分割的整体,只有全部操作都完成了,才算结束;其中任何一个操作执行失败,整个事务都要撤销。 ? 一致性:即事务不能破坏数据库的完整性和业务逻辑的一致性。事务不管成功还是失败,事务结束时,整个数据库内部数据都是正确的。 ? 隔离性:即在并发的数据库操作时,不同的事务操作相同的数据时,每个事务都有自己的完整的数据空间。一个事务不会看到或拿到另一个事务正修改到一半的数据,这些数据要么是另一个事务修改前的,要么是另一个事务修改后提交的。拥有这个特性,是为了在数据库并发操作过程中,保证所有并发操作的正确性。 ? 持久性:即事务成功提交后,数据就被永久地保存到数据库,重新启动数据库系统后,数据仍然保存在数据库系统中。 11.1.2 Hibernate的事务 将事务管理委托给JDBC进行处理是最简单的实现方式,Hibernate对于JDBC事务的封装也比较简单。例如下面的代码: ?Session session=sessionFactory.openSession(); Transaction tx=session.beginTransaction(); ... mit(); ?从JDBC层面而言,上面的代码实际上对应着: ?Connection cn=getConnection; cn.setAutoCommit(false); // JDBC调用相关的SQL语句 mit(); 11.1.2 Hibernate的事务 在sessionFactory.openSession()语句中,Hibernate会初始化数据库连接。与此同时,将其AutoCommit设为关闭状态(false),即一开始从SessionFactory获得的session,其自动提交属性已经被关闭。下面的代码不会对数据库产生任何效果: ?session session=session.Factory.openSession(); session.save(user); session.close(); ?这实际上相当于JDBC Connection的AutoCommit属性被设为false,执行了若干JDBC操作之后,没有调用commit操作。 如果要使代码真正作用到数据库,必须显示地调用Transaction指令,例如下面的代码: ?Session session =sessionFactory.openSession(); Transaction tx=sessio.beginTransaction(); session.save(user); mit(); session.close(); 11.1.2 Hibernate的事务 Hibernate的事务应用一般分为下面几个步骤: (1)通过SessionFactoy获得Session对象,例如下面的代码: ?Session session?=?sessionFactory.openSession(); ?(2)通过Session对象开始一个事务,例如下面的代码: ?Transaction t=session.beginTransaction(); ?(3)进行相关的数据操作。 (4)事务提交,例如下面的代码: ?mit(); ?(5)如果事务处理出现异常,则撤销事务(通常叫做事务回滚),例如下面的代码: ?t.rollback(); ?(6)关闭Session,结束操作,例如下面的代码: ?session.close(); ?一个完整的应用Hibernate事务的实例。 11.1.2 Hibernate的事务 2.基于JTA的事务管理概念 JTA(Java Transaction API)是由Java EE Transaction Manager管理的事务,其最大的特点是调用UserTransaction接口的begin()、commit()和rollback()方法来完成事务范围的界定、事务的提交和回滚。JTA可以实现同一事务对应不同的数据库。 JTA主要用于分布式的多个数据源的两阶段提交的事务,而JDBC的Connection提供单个数据源的事务,后者因为只涉及一个数据源,所以其事务可以由数据库自己单独实现,而JTA事务因为其分布式和多数据源的特性,不可能由任何一个数据源实现事务。因此,JTA中的事务是由“事务管理器”来实现的,它会在多个数据源之间统筹事务,具体使用的技术就是所谓的“两
您可能关注的文档
- 第7篇 异常处理机制.ppt
- C语言 08篇_函数.ppt
- 第1篇oracle数据库概述.ppt
- 第七章 Net面向对象程序设计-19-枚举集合-2010-2011-2.ppt
- 代码生成器使用方法解读.pdf
- 如何使用HP USB Key Utility刷新BIOS及FIRMWARE.doc
- 数据库课件第4篇.ppt
- 市场调查和预测-第四章.ppt
- SS8050三极管规格书:三极管SS8050参数和封装尺寸.pdf
- Net面向对象程序设计-2-使用变量操作符及表达式-2010-2011-2.ppt
- 2024年江西省高考政治试卷真题(含答案逐题解析).pdf
- 2025年四川省新高考八省适应性联考模拟演练(二)物理试卷(含答案详解).pdf
- 2025年四川省新高考八省适应性联考模拟演练(二)地理试卷(含答案详解).pdf
- 2024年内蒙通辽市中考化学试卷(含答案逐题解析).docx
- 2024年四川省攀枝花市中考化学试卷真题(含答案详解).docx
- (一模)长春市2025届高三质量监测(一)化学试卷(含答案).pdf
- 2024年安徽省高考政治试卷(含答案逐题解析).pdf
- (一模)长春市2025届高三质量监测(一)生物试卷(含答案).pdf
- 2024年湖南省高考政治试卷真题(含答案逐题解析).docx
- 2024年安徽省高考政治试卷(含答案逐题解析).docx
文档评论(0)