`
mzhj
  • 浏览: 227514 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

03、搭建JPA开发环境和全局事务介绍

阅读更多

persistence.xml(JPA规范要求在类路径的META-INF目录下) ,如下图:


 

<persistence xmlns="http://java.sun.com/xml/ns/persistence"     
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" 
    version="1.0">

	<persistence-unit name="itcast" transaction-type="RESOURCE_LOCAL">	
	   <properties>
	    <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />
	    <property name="hibernate.hbm2ddl.auto" value="update"/>
	    <property name="hibernate.connection.driver_class" value="org.gjt.mm.mysql.Driver" />
	    <property name="hibernate.connection.username" value="root" />
	    <property name="hibernate.connection.password" value="123456" />
	    <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/itcast?useUnicode=true&amp;characterEncoding=UTF-8" />    
	   </properties>	
	</persistence-unit>
    
</persistence>

 

persistence.xml这个配置文件的模板可以从哪里找到呢?
    因为JPA是一规范,所以你即可以从JPA的规范文档里找到,也可以从任何一个实现了JPA规范的实现产品中找到。好比Hibernate,可以从hibernate-entitymanager-3.4.0.GA\doc\reference\en\html_single\index.html中找到。

    <persistence-unit><persistence-unit/>持久化单元,简单说,就是代表一堆实体bean的集合,那么这堆实体bean,我们叫他们做实体bean单元。我们在学Hibernate就已知道,他们就是专门用于跟数据库映射的普通的Java对象,在我们JPA里面,这些对象叫做实体bean。持久化单元就是一堆实体bean的集合,我们为这堆集合取个名称,<persistence-unit name="..."><persistence-unit/>

全局事务 本地事务
------------------------------------------------------------------------------------------------------------------------------------------------------------------------
     全局事务:资源管理器管理和协调的事务,可以跨越多个数据库和进程。资源管理器一般使用 XA 二阶段提交协议与“企业信息系统”(EIS) 或数据库进行交互。
     本地事务:在单个 EIS 或数据库的本地并且限制在单个进程内的事务。本地事务不涉及多个数据来源。

     <persistence-unit><persistence-unit/>标签还有个属性,是transaction-type(事务的类型),这属性有两个值,分别是JTA(全局事务)和RESOURCE_LOCAL(本地事务)。
    这里我们配置为transaction-type="RESOURCE_LOCAL",因为我们只针对一个数据库进行操作,也说只针对一个事务性资源进行操作。

    以前我们学习的事务类型都属于本地事务。 JTA(全局事务)和RESOURCE_LOCAL(本地事务)有什么区别呢?在某些应用场合,只能使用全局事务,比如:
有两个数据库:
1.mysql 2.oracle  现在有个业务需求--转账
step 1> update mysql_table set amount=amount-xx where id=aaa 发生扣钱,假设是在mysql数据库扣钱的。
step 2> update oracle_table set amount=amount+xx where id=bbb 加钱,假设是在oracle数据库扣钱的。
现在怎么确保两个语句在同一个事务里执行呢?

以前在JDBC里是这样做
connection = mysql 连接mysql
connection.setAutoCommit(false);  不自动提交
1> update mysql_table set amount=amount-xx where id=aaa 发生扣钱,假设是在mysql数据库扣钱的。
2> update oracle_table set amount=amount+xx where id=bbb  发生在oracle数据库
connection.commit();
执行这两条语句,然后通过connection对象提交事务.我们这样子做只能确保这两个语句在同一个数据库mysql里面实现在同一个事务里执行。 但是问题是我们现在是要连接到oracle数据库,是不是需要connection2啊?

connection = mysql 连接mysql
connection2 = oracle 连接oracle
connection.setAutoCommit(false);  不自动提交
1> update mysql_table set amount=amount-xx where id=aaa 发生扣钱,假设是在mysql数据库扣钱的。
2> update oracle_table set amount=amount+xx where id=bbb  发生在oracle数据库
connection.commit();
connection2.setAutoCommit(false);
connection2.commit();
事务只能在一个connection里打开,并且确保两条语句都在该connection里执行,这样才能让两条语句在同一事务里执行,现在问题就在于connection2是连接到oracle数据库的,那么connection2再开事务有意义吗?它能确保吗?不能,所以在这种情况下就只能使用全局事务了。
这种情况下用普通JDBC操作是满足不了这个业务需求的,这种业务需求只能使用全局事务,本地事务是无法支持我们的操作的,因为这时候,事务的生命周期不应该局限于connection对象的生命周期范围

全局事务怎么做呢?
JPA.getUserTransaction().begin();      首先要全局事务的API,不需要我们编写,通常容器已经提供给我们了,我们只需要begin一下
connection = mysql 连接mysql
connection2 = oracle 连接oracle
connection--> update mysql_table set amount=amount-xx where id=aaa 发生扣钱,假设是在mysql数据库扣钱的。
connection2--> update oracle_table set amount=amount+xx where id=bbb 发生在oracle数据库
JPA.getUserTransaction().commit();

那么它是怎么知道事务该提交还是回滚呢?
这时候它使用了二次提交协议。二次提交协议简单说就这样:如果你先执行第一条语句,执行的结果先预提交到数据库,预提交到数据库了,数据库会执行这条语句,然后返回一个执行的结果,这个结果假如我们用布尔值表示的话,成功就是true,失败就是false.然后把执行的结果放入一个(假设是List)对象里面去,接下来再执行第二条语句,执行完第二条语句之后(也是预处理,数据库不会真正实现数据的提交,只是说这条语句送到数据库里面,它模拟下执行,给你返回个执行的结果),假如这两条语句的执行结果在List里面都是true的话,那么这个事务就认为语句是成功的,这时候全局事务就会提交。 二次提交协议,数据库在第一次提交这个语句时,只会做预处理,不会发生真正的数据改变,当我们在全局事务提交的时候,这时候发生了第二次提交,那么第二次提交的时候才会真正的发生数据的改动。
    如果说在执行这两条语句中,有一个出错了,那么List集合里就有个元素为false,那么全局事务就认为你这个事务是失败的,它就会进行回滚,回滚的时候,哪怕你的第二条语句在第一次提交的时候是成功的,它在第二次提交的时候也会回滚,那么第一次的更改也会恢复到之前的状态,这就是二次提交协议。(可以查看一下数据库方面的文档来了解二次提交协议)

    回到persistence.xml的配置里面去,事务类型有两种,什么时候该用全局事务(JTA)?什么时候改用本地事务(RESOURCE_LOCAL)?应有你的业务应用需求来定,我们的大部分应用只是需要本地事务。全局事务通常是在应用服务器里使用,比如weblogic,JBoss,学习EJB3后给大家介绍。 企业面试时被问到就要注意了(事务类型有哪几种?分别用在什么场景下?)

  • 大小: 7.2 KB
分享到:
评论

相关推荐

    03_JPA详解_搭建JPA开发环境和全局事务介绍.zip

    本资料主要针对JPA的使用进行详细讲解,包括如何搭建JPA开发环境以及全局事务的介绍。 **一、JPA开发环境的搭建** 1. **集成环境选择**: JPA可以与多种应用服务器和IDE集成,如Tomcat、Jetty、Eclipse、IntelliJ ...

    03_传智播客JPA详解_搭建JPA开发环境和全局事务介绍

    了解以上基础后,你可以观看"03_传智播客JPA详解_搭建JPA开发环境和全局事务介绍"的自学视频,视频将更深入地展示如何操作和实践。学习过程中,你将看到如何配置JPA环境,创建并管理实体,以及如何在实际项目中运用...

    JPA详解视频教程 第3讲 搭建JPA开发环境和全局事务介绍.avi

    JPA用于整合现有的ORM技术,可以简化现有Java EE和Java SE应用对象持久化的开发工作,实现ORM的统一。JPA详解视频教程 第3讲 搭建JPA开发环境和全局事务介绍.avi

    JPA环境搭建及JPA实例与JPA主键生成策略

    在开始使用JPA之前,我们需要搭建一个基本的开发环境。以下是一些关键步骤: 1. **引入依赖**:如果你正在使用Maven或Gradle,你需要在项目的`pom.xml`或`build.gradle`文件中添加JPA和相关数据库驱动的依赖。例如...

    传智播客JPA学习笔记.pdf

    搭建JPA开发环境和全局事务介绍** 配置JPA环境涉及添加JPA相关的依赖库,如Hibernate或EclipseLink,设置数据源,创建EntityManagerFactory,以及在应用服务器中配置全局事务管理。 **4. 第一个JPA实例与JPA主键...

    传智播客JPA学习笔记修改免积分版

    #### 四、JPA开发环境与全局事务介绍 - **开发环境搭建**: - 配置必要的库文件和依赖项,例如 JPA 规范实现库(如 Hibernate)、数据库驱动等。 - 设置应用程序上下文,配置持久化单元(persistence unit),指定...

    Spring Data JPA Demo

    Spring Data JPA 是一个强大的框架,它简化了与Java Persistence API (JPA) 的交互...同时,了解Spring Data JPA 如何与Hibernate 配合工作,以及如何处理复杂的查询和事务管理,这些都是在实际开发中非常重要的技能。

    SpringMVC+Mybatis的环境搭建

    本教程将详细讲解如何搭建这样的开发环境。 首先,我们需要理解这三个核心技术的核心概念: 1. **Spring**:Spring 是一个开源的Java平台,它简化了开发过程,提供了依赖注入(DI)和面向切面编程(AOP)等核心...

    SpringBoot+Atomikos+动态多数据源+事务+2种切换数据源的方式

    Atomikos是一个开源的事务管理器,它实现了Java Transaction API (JTA),支持全局事务处理。在分布式系统中,当操作涉及到跨多个数据源时,Atomikos可以确保事务的一致性和原子性,确保业务逻辑的正确执行。 1. **...

    搭建SSH框架项目

    SSH框架是Java开发中常用的三大框架整合,包括Spring、Struts和Hibernate。...在实际开发中,可能还需要集成其他组件,如MyBatis、Spring Boot、Spring Data JPA等,以适应更复杂的需求和提高开发效率。

    Spring MVC 框架搭建及详解

    **一、Spring MVC 环境搭建** 1. **引入依赖库**: - 对于 Spring MVC,你需要引入 `spring.jar` 和 `spring-webmvc.jar`,这两个是 Spring 框架的核心库。此外,`commons-logging.jar` 提供日志支持,`cglib-node...

    毕业设计,使用SpringBoot &amp; Vue 搭建。.zip

    6. **Spring Data JPA**:简化数据库访问,支持ORM(对象关系映射)和事务管理。 **Vue.js知识点:** 1. **组件化**:Vue.js的核心特性,将UI拆分成可复用的组件,提高代码复用性和可维护性。 2. **虚拟DOM**:Vue...

    SSH2框架搭建实例(spring3.2+strust2.3.4+hibernate4.2)

    1. **环境准备**:确保安装了Java开发环境(JDK),并配置好相应的环境变量。 2. **创建Maven或Gradle项目**:SSH2项目通常使用构建工具来管理依赖,选择Maven或Gradle并创建相应的项目结构。 3. **添加依赖**:在...

    spring boot+Druid+mybatis搭建多数据源java项目

    通常还需要一个主数据源,用于处理全局事务。 5. **动态数据源**: 使用`AbstractRoutingDataSource`或者第三方库如`Druid-Spring-boot-starter`,可以根据业务逻辑动态切换数据源。这通常涉及到在代码中设置当前...

    搭建SpringMVC(数据访问 Springdata)

    SpringMVC和SpringData是Java开发中常用的两个框架,它们分别负责Web应用的模型-视图-控制器架构和数据访问层的操作。在这个项目中,我们将深入理解如何将这两个框架集成,构建一个完整的数据访问系统。 首先,让...

    SSH框架的搭建

    SSH框架是Java开发中常用的三大框架,包括Struts 2、Spring 2和Hibernate 3。这三大框架的整合能够帮助开发者构建高效、模块化的Web应用程序。下面将详细讲解SSH框架搭建的过程及其重要知识点。 首先,让我们从...

    JBOSS中文文档

    9. **交易管理**:涵盖JBoss的事务处理机制,包括本地事务和全局事务的配置与管理。 **四、JBoss 管理与监控** 10. **管理工具**:介绍JBoss的管理工具,如JMX(Java Management Extensions)和管理控制台,以及...

    SSH2框架搭建实例(spring3.2+strust2.3.4+hibernate4.2)用户管理

    本实例将详细介绍如何使用SSH2(Spring 3.2、Struts 2.3.4和Hibernate 4.2)搭建一个用户管理系统的全过程。 首先,我们需要理解SSH框架的核心概念: 1. Spring:Spring是一个全面的Java企业级应用开发框架,提供...

    xx_parent.zip

    parent.zip】是一个压缩包文件,包含了学习基础分布式框架搭建的相关资料,使用了Java 8(JDK1.8)作为开发环境,采用了Apache Maven 3.5.4作为项目构建工具,同时集成了PostgreSQL数据库以及Spring Data JPA作为...

    jta-1_0_1B-classes.jar

    在实际应用中,JTA常与JTS(Java Transaction Service)配合使用,JTS是JTA的完整实现,提供了一个完整的事务服务,支持全局事务。通过JTA,开发者可以编写出事务一致性极高的应用,即使在分布式环境下也能保证数据...

Global site tag (gtag.js) - Google Analytics