<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    千里冰封
    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.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注入到使用它的地方了。






    盡管千里冰封
    依然擁有晴空

    你我共同品味JAVA的濃香.
    posted on 2008-10-19 18:38 千里冰封 閱讀(5059) 評論(3)  編輯  收藏 所屬分類: JAVAEE

    FeedBack:
    # re: 使用JPA的不同實現的配置[未登錄]
    2008-10-19 22:56 | ytl
    好久沒看到你寫文章啦。。  回復  更多評論
      
    # re: 使用JPA的不同實現的配置
    2008-10-21 09:40 | attend
    多謝分享.  回復  更多評論
      
    # re: 使用JPA的不同實現的配置[未登錄]
    2009-09-22 01:14 | CC
    除了persistence.xml還要配置其它的地方嗎?
    想在tomcat中使用它  回復  更多評論
      
    主站蜘蛛池模板: 精品少妇人妻AV免费久久洗澡| a级毛片在线免费看| 2021在线永久免费视频| 亚洲综合网站色欲色欲| 特a级免费高清黄色片| 免费一级做a爰片性色毛片| 亚洲AV综合色区无码一二三区 | 国产婷婷成人久久Av免费高清| 日本中文一区二区三区亚洲| 国产AV无码专区亚洲AV麻豆丫| 毛片A级毛片免费播放| 亚洲欧美国产国产一区二区三区| 日本一区二区三区免费高清| 亚洲中文字幕无码久久2020| 岛国大片免费在线观看| 亚洲精品无码久久久久APP| 最近中文字幕无吗高清免费视频| 亚洲成a人片77777群色| 永久免费在线观看视频| 亚洲大尺码专区影院| 免费AA片少妇人AA片直播| 亚洲日韩乱码久久久久久| 国产成人A在线观看视频免费| 亚洲国产美女精品久久久久| 免费毛片在线看片免费丝瓜视频| 亚洲国产精品人久久电影| 男男AV纯肉无码免费播放无码| 国产亚洲福利在线视频| 成全高清视频免费观看| 黄色大片免费网站| 丝袜熟女国偷自产中文字幕亚洲| 免费国产污网站在线观看15| 亚洲日韩国产精品无码av| 国产精品免费视频网站| 手机永久免费的AV在线电影网| 自拍偷自拍亚洲精品被多人伦好爽| 久久免费福利视频| 亚洲阿v天堂在线| 亚洲综合一区二区三区四区五区| 在线毛片片免费观看| 久久青青草原亚洲AV无码麻豆|