千里冰封
java 浓香四溢
posts - 151,comments - 2801,trackbacks - 0
以前使用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.persistenceproviderprovider>
    
<class>com.hadeslee.jpaentity.departmentclass>
    
<class>com.hadeslee.jpaentity.personclass>
    
<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.hibernatepersistenceprovider>
    
<class>com.hadeslee.jpaentity.departmentclass>
    
<class>com.hadeslee.jpaentity.personclass>
   <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的数据源的。并且不能使用
true这个属性。
本文重点是记录下两个常用的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.persistenceproviderprovider>
    
<jta-data-source>mobileoamssqljta-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.hibernatepersistenceprovider>
    
<jta-data-source>mobileoamysqljta-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注入到使用它的地方了。






尽管千里冰封
依然拥有晴空

你我共同品味java的浓香.
posted on 2008-10-19 18:38 千里冰封 阅读(4986) 评论(3)  编辑  收藏 所属分类: javaee

feedback:
# re: 使用jpa的不同实现的配置[未登录]
2008-10-19 22:56 |
好久没看到你写文章啦。。  回复  
  
# re: 使用jpa的不同实现的配置
2008-10-21 09:40 |
多谢分享.  回复  
  
# re: 使用jpa的不同实现的配置[未登录]
2009-09-22 01:14 |
除了persistence.xml还要配置其它的地方吗?
想在tomcat中使用它  回复  
  
网站地图