以前使用JPA的实现是toplink,现在改为hibernate,所以要修改persistence.xml文件,两者的配置有一些不一样,并且在EE环境下面和SE的环境下面也有不一样,还有一点,那就是当persistence.xml里面有些格式出错的时候,虽然出错的不是我们需要的那个单元,但也会使得整个persistence.xml报废。
下面帖的是在SE的环境下面使用toplink和hibernate的实现,两者都写在同一个persistence.xml里面。这样切换起来也方便一些。
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" 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 http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="TestSSH2PU" transaction-type="RESOURCE_LOCAL">
<provider>oracle.toplink.essentials.PersistenceProvider</provider>
<class>com.hadeslee.jpaentity.Department</class>
<class>com.hadeslee.jpaentity.Person</class>
<properties>
<property name="toplink.jdbc.user" value="sa"/>
<property name="toplink.jdbc.password" value="hadeslee"/>
<property name="toplink.jdbc.url" value="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=testSSH"/>
<property name="toplink.jdbc.driver" value="com.microsoft.jdbc.sqlserver.SQLServerDriver"/>
<property name="toplink.ddl-generation" value="create-tables"/>
</properties>
</persistence-unit>
<persistence-unit name="TestSSH1PU2" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.hadeslee.jpaentity.Department</class>
<class>com.hadeslee.jpaentity.Person</class>
<properties>
<property name="hibernate.connection.driver_class" value="com.microsoft.jdbc.sqlserver.SQLServerDriver"/>
<property name="hibernate.connection.url" value="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=testSSH"></property>
<property name="hibernate.connection.username" value="sa"></property>
<property name="hibernate.connection.password" value="hadeslee"></property>
<property name="hibernate.show_sql" value="true"></property>
<property name="hibernate.dialect" value="org.hibernate.dialect.SQLServerDialect"></property>
<property name="hibernate.current_session_context_class" value="thread"></property>
</properties>
</persistence-unit>
</persistence>
在SE的环境下面,是不能使用容器的JTA的数据源的。并且不能使用
<exclude-unlisted-classes>true</exclude-unlisted-classes>这个属性。
本文重点是记录下两个常用的JPA的实现的配置。目前是在SE环境下的配置。EE环境下面的配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" 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 http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="unit_mssql" transaction-type="JTA">
<provider>oracle.toplink.essentials.PersistenceProvider</provider>
<jta-data-source>MobileOAMSSQL</jta-data-source>
<properties>
<property name="toplink.ddl-generation" value="create-tables"/>
<property name="toplink.logging.level" value="FINE"/>
</properties>
</persistence-unit>
<persistence-unit name="MyApp-ejbPU2" transaction-type="JTA">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<jta-data-source>MobileOAMYSQL</jta-data-source>
<properties>
<property name="hibernate.hbm2ddl.auto" value="update"/>
<property name="hibernate.show_sql" value="true"/>
</properties>
</persistence-unit>
</persistence>
在EE环境下面使用JPA配置就简单了许多,首先他可以把当前模块的CLASS文件都包括进来,不用手工指定。并且也少了很多有关于数据库连接的操作,因为这个时候都是从容器里面去取数据源的。并且此时的事务是由容器去管理的,也就是使用JTA,不再是RESOURCE_LOCAL了。这样在代码里面就不用em.getTransaction().begin();和em.getTransaction().commit()了,并且可以使用注入功能,把EntityManager注入到使用它的地方了。
分享到:
相关推荐
Spring 是一个强大的轻量级应用框架,而 OpenJPA 是一个开源的 Java Persistence API (JPA) 实现,它允许开发者将对象关系映射(ORM)功能无缝集成到应用程序中。在本文中,我们将深入探讨如何将 Spring 框架与 Open...
**Spring MVC + JPA 集成实例** 在Java企业级开发中,Spring MVC和JPA(Java Persistence API)是两个非常重要的框架。Spring MVC作为Spring框架的一部分,用于构建Web应用程序的模型-视图-控制器架构,而JPA则是...
#### 四、Spring MVC中的JPA集成步骤 1. **添加依赖**:在Maven或Gradle项目中添加Spring MVC、Spring Data JPA以及相应的数据库驱动的依赖。 2. **配置数据源**:在Spring配置文件中定义数据源,例如使用`...
本项目涉及的是"SH+MQ+JPA集成",即Spring、ActiveMQ和JPA的整合,结合了Web应用开发、消息队列以及持久化管理的重要技术。下面将详细解释这些技术及其集成的关键点。 **Spring框架**: Spring是Java平台上的一个...
标题“Spring Struts2 JPA集成”涉及到的是Java企业级开发中的三大框架——Spring、Struts2和JPA(Java Persistence API)的整合应用。这是一个常见的技术栈组合,用于构建可扩展且高效的Web应用程序。 首先,...
这个"spring3.1 struts2.3 hibernate4.1 jpa集成小例子"是一个典型的Java Web项目,它展示了如何将Spring 3.1、Struts 2.3、Hibernate 4.1和Java Persistence API (JPA) 这四大组件融合到一个应用中。接下来,我们将...
在SSH框架中集成JPA,我们可以利用Spring的数据访问抽象层,通过配置来启用JPA支持。 注解在JPA中的使用极大地简化了数据库模型的定义。例如,我们可以使用@Entity注解标记一个类作为实体,@Table注解指定对应的...
Spring、Struts2和JPA是Java开发中常用的三大框架,它们各自负责应用程序的不同层面:...这个压缩包中的代码和配置文件将为我们提供一个直观的学习素材,让我们能够亲手实践并理解Spring、Struts2和JPA集成的全过程。
而JPA(Java Persistence API)和MyBatis是两种流行的数据访问技术,它们各自有着不同的优势和应用场景。本示例将探讨如何在Spring4环境下集成JPA与MyBatis3,帮助开发者理解如何在同一个项目中利用这两种技术。 **...
通常,我们会为JPA和MyBatis设置不同的数据源,并使用Spring的多数据源配置。每个数据源都有自己的事务管理器,JPA使用JpaTransactionManager,而MyBatis则使用DataSourceTransactionManager。在应用中,我们需要...
对于JPA集成,我们需要配置数据源、实体管理工厂、事务管理器以及JPA的配置信息。 1. **配置数据源**: 使用`@Bean`注解创建一个DataSource实例,通常我们会选择一个连接池如HikariCP或Apache DBCP。例如: ```...
在Spring Boot项目中集成Spring Data JPA,首先需要在构建文件(如Gradle或Maven)中引入相关依赖,例如对于Gradle,可以添加`spring-boot-starter-data-jpa`和数据库驱动(如MySQL)的依赖。然后,在配置文件(如...
ORM,全称Object-Relational Mapping,中文名为对象关系映射,是一种编程技术,用于将关系数据库的数据模型映射到面向对象的编程语言中。它使得开发者可以使用面向对象的方式来操作数据库,而无需直接编写SQL语句,...
**Spring Boot与JPA集成** 1. **Starter POM**: Spring Boot通过添加spring-boot-starter-data-jpa依赖,自动配置JPA和数据源。 2. **DataSource**: Spring Boot自动配置数据源,只需在application.properties或...
二、Spring 2.5与JPA集成的优势 1. 解耦:Spring作为IoC容器,可以轻松管理JPA的SessionFactory或EntityManagerFactory,实现依赖注入。 2. 支持多种JPA实现:Spring支持Hibernate、EclipseLink等多种JPA提供商,...