JPA persistence.xml

以前使用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注入到使用它的地方了。

發佈了63 篇原創文章 · 獲贊 2 · 訪問量 8288
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章