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

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

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

    paulwong

    小議JPA

    以前和數據庫打交道的標準INTERFACE是JDBC,放SQL語句,執行,就可以有結果。隨著近年ORM的興起,以對象的方式存取數據庫大行其道。于是產生了JPA。

    也是一套INTERFACE,以ORM的方式提供,由廠商實現,如ECLIPSE LINK,HIBERNATE,OPENEJB等。

    ENTITYMANAGERFACTORY:根據配置文件制造ENTITYMANAGER
    ENTITYMANAGER:以ORM的方式提供操作數據庫的功能
    TRANSACTION:事務保證
    PERSISTENCE.XML:鏈接數據庫信息,事務類型,重定義JPA的實現廠商等的配置信息

    在容器環境下使用:

    如果事務是RESOURCE_LOCAL的方式,則合用端需干所有的事情,如構造ENTITYMANAGER,打開事務,關閉事務等。類似于BMT。
    以下是在服務器環境中合用RESOURCE_LOCAL型的JPA

    事先要在容器中添加數據源。

     persistence.xml
    <?xml version="1.0" encoding="UTF-8" ?>
    <persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">

      <!-- Tutorial "unit" -->
      <persistence-unit name="Tutorial" transaction-type="RESOURCE_LOCAL">
        <non-jta-data-source>myNonJtaDataSource</non-jta-data-source>
        <class>org.superbiz.jpa.Account</class>
      </persistence-unit>

    </persistence>


    import javax.persistence.EntityManagerFactory;
    import javax.persistence.EntityManager;
    import javax.persistence.EntityTransaction;
    import javax.persistence.PersistenceUnit;

    public class MyEjbOrServlet  {

        @PersistenceUnit(unitName="Tutorial")
        private EntityManagerFactory factory;

        // Proper exception handling left out for simplicity
        public void ejbMethodOrServletServiceMethod() throws Exception {
            EntityManager entityManager = factory.createEntityManager();

            EntityTransaction entityTransaction = entityManager.getTransaction();

            entityTransaction.begin();

            Account account = entityManager.find(Account.class, 12345);

            account.setBalance(5000);

            entityTransaction.commit();
        }

        
    }


    以下是JTA方式的JPA,容器+EJB+JPA+JTA,容器會在EJB的方法調用前打開一個事務,在方法退出后,提交事務,并且如果是多個數據源的,即有多個ENTITYMANAGER的
    可以保證一致性,即全局事務。相當于之前的先調用USERTRANSACTION,BEGIN,COMMIT。

    事先要在容器中添加數據源。

     persistence.xml
    <?xml version="1.0" encoding="UTF-8" ?>
    <persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">

      <!-- Tutorial "unit" -->
      <persistence-unit name="Tutorial" transaction-type="JTA">
        <jta-data-source>myJtaDataSource</jta-data-source>
        <non-jta-data-source>myNonJtaDataSource</non-jta-data-source>
        <class>org.superbiz.jpa.Account</class>
      </persistence-unit>

    </persistence>


    EJB
    import javax.ejb.Stateless;
    import javax.ejb.TransactionAttribute;
    import javax.ejb.TransactionAttributeType;
    import javax.persistence.EntityManager;
    import javax.persistence.PersistenceContext;

    @Stateless
    public class MyEjb implements MyEjbInterface {

        @PersistenceContext(unitName = "Tutorial")
        private EntityManager entityManager;

        // Proper exception handling left out for simplicity
        @TransactionAttribute(TransactionAttributeType.REQUIRED)
        public void ejbMethod() throws Exception {

        Account account = entityManager.find(Account.class, 12345);

        account.setBalance(5000);

        }
    }


    如果是J2SE環境下使用JPA,則又是不一樣的。


    persistence.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">
        <persistence-unit name="SimplePU" transaction-type="RESOURCE_LOCAL">
            <provider>org.hibernate.ejb.HibernatePersistence</provider>
            <class>com.someone.jmail.valueobject.CallActivity</class>
            <class>com.someone.jmail.valueobject.Email</class>
            <properties>
                <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
                <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/test" />
                <property name="hibernate.connection.username" value="root" />
                <property name="hibernate.connection.password" value="12345" />
                <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />
                <property name="hibernate.show_sql" value="false"/>
                <property name="hibernate.format_sql" value="true"/>
                <property name="hibernate.use_sql_comments" value="false"/>
                <property name="hibernate.hbm2ddl.auto" value="none"/>
            </properties>
        </persistence-unit>
        
    </persistence>


    Dao:

    public class UserDaoImpl implements UserDao { 
     public AccountInfo save(AccountInfo accountInfo) { 
     EntityManagerFactory emf = 
     Persistence.createEntityManagerFactory("SimplePU"); 
     EntityManager em = emf.createEntityManager(); 
     em.getTransaction().begin(); 
     em.persist(accountInfo); 
     em.getTransaction().commit(); 
     emf.close(); 
     return accountInfo; 
        } 
     } 


    posted on 2013-08-14 18:17 paulwong 閱讀(603) 評論(0)  編輯  收藏 所屬分類: J2EE

    主站蜘蛛池模板: 中文字幕亚洲免费无线观看日本| MM1313亚洲精品无码久久| 麻豆一区二区免费播放网站| 亚洲中文无码永久免费| 亚洲精品WWW久久久久久| 国产免费拔擦拔擦8X高清在线人 | 免费无码又爽又刺激毛片| 亚欧国产一级在线免费| 亚洲精品中文字幕乱码| 国产一精品一aⅴ一免费| 无码日韩精品一区二区免费暖暖| 狠狠色伊人亚洲综合网站色| 国产成人精品久久亚洲| 2020久久精品国产免费| xvideos永久免费入口| 亚洲欧洲日韩国产| 亚洲午夜精品久久久久久浪潮| 亚洲香蕉免费有线视频| 一区二区三区免费视频观看| 亚洲天堂2016| 亚洲国产精品无码久久一线| 免费精品一区二区三区在线观看| 久草免费福利视频| 人妻无码中文字幕免费视频蜜桃 | 美女免费精品高清毛片在线视| 亚洲第一视频网站| 亚洲精品美女久久久久99小说| 免费看美女裸露无档网站| 青青操免费在线视频| 美女视频黄频a免费观看| 亚洲一卡2卡4卡5卡6卡在线99| 国产亚洲一区二区在线观看| 四虎国产精品免费久久影院| 成人免费午夜无码视频| 国产免费网站看v片在线| 麻花传媒剧在线mv免费观看 | 成人A毛片免费观看网站| 亚洲一区二区三区免费观看| 亚洲av无码专区国产乱码在线观看| 国产99视频精品免费视频7| 无码日韩人妻av一区免费|