`

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

阅读更多

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


 

Xml代码 复制代码
  1. <persistence xmlns="http://java.sun.com/xml/ns/persistence"        
  2.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3.     xsi:schemaLocation="http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"    
  4.     version="1.0">  
  5.   
  6.     <persistence-unit name="itcast" transaction-type="RESOURCE_LOCAL">       
  7.        <properties>  
  8.         <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />  
  9.         <property name="hibernate.hbm2ddl.auto" value="update"/>  
  10.         <property name="hibernate.connection.driver_class" value="org.gjt.mm.mysql.Driver" />  
  11.         <property name="hibernate.connection.username" value="root" />  
  12.         <property name="hibernate.connection.password" value="root" />  
  13.         <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=UTF-8" />       
  14.        </properties>     
  15.     </persistence-unit>  
  16.        
  17. </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后给大家介绍。 企业面试时被问到就要注意了(事务类型有哪几种?分别用在什么场景下?)

分享到:
评论

相关推荐

    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学习笔记修改免积分版

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

    传智播客JPA学习笔记.pdf

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

    Spring Data JPA Demo

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

    springmvc搭建详解

    Spring MVC 是一款广泛使用的 Java Web 开发框架,它提供了一种模型-视图-控制器(MVC)架构来构建可维护和可扩展的Web应用程序。Spring MVC 提供了丰富的功能,包括请求映射、数据绑定、验证、本地化和视图解析等,...

    Spring MVC 框架搭建及详解

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

    struts2-hibernate3-spring整合需要的全部jar包

    Struts2、Hibernate3和Spring是Java开发中常用的三大框架,它们各自负责不同的职责:Struts2用于控制应用程序的流程,Hibernate3则是优秀的对象关系映射(ORM)框架,Spring则提供全面的依赖注入(DI)和面向切面...

    SpringMVC+Mybatis的环境搭建

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

    SpringMVC精品资源--vans 基于SpringBoot构建的后端开发脚手架项目,完美整合springmvc.zip

    SpringBoot则是Spring框架的一个子项目,旨在简化Spring应用的初始搭建以及开发过程。它集成了许多默认配置,使得开发者能够快速启动项目,而无需进行大量的配置工作。 "SpringMVC精品资源--vans" 是一个基于...

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

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

    jta-1_0_1B-classes.jar

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

    spring2.5学习PPT 传智博客

    2. **搭建与测试Spring开发环境** - 安装配置JDK和IDE,如Eclipse或IntelliJ IDEA。 - 设置Spring库并创建第一个Spring应用,包括编写XML配置文件。 - 测试配置环境,确保Spring可以正确初始化和管理Bean。 3. *...

    SpringBoot专栏教程-邮件.pdf

    - **定义**:Spring Boot是由Pivotal团队提供的全新框架,其设计目标是简化新Spring应用的初始搭建以及开发过程。 - **特点**: - 开箱即用:减少XML配置,提供默认配置。 - 独立运行:无需WAR包,可独立运行。 -...

    mybatis与spring整合全部jar包(包括springmvc).rar

    SSM(Spring、Spring MVC、MyBatis...这个压缩包提供的jar包涵盖了SSM整合所需的全部基础库,包括Spring、Spring MVC、MyBatis以及它们的依赖,使得开发者可以快速搭建起一个完整的开发环境,进行Java Web应用的开发。

    搭建SpringMVC(数据访问 Springdata)

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

    搭建SSH框架项目

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

    spring-boot-mybatis-plus 一套打通 有注释 打开就可使用

    这样的项目通常包含完整的配置和示例代码,使得开发者可以立即上手,无需从零开始配置环境。 描述中提到的是最新版本的Spring Boot 2.x和MyBatis Plus。Spring Boot 2.x带来了许多改进和新特性,比如更好的性能、新...

Global site tag (gtag.js) - Google Analytics