Hibernate框架兩種配置文件詳解

Hibernate配置文件主要功能是配置數據庫連接和Hibernate運行時所需的各種屬性,配置文件應該位於JAVA應用或者JAVA Web應用的類文件中。

  Hibernate配置文件的方式有兩種:一種是通過XML格式文件配置,一種通過JAVA屬性文件配置,屬性文件配置採用的是“鍵=值”對的方式。建議採用XML格式文件配置格式,XML配置文件可以直接對映射文件進行配置,配置中每一個類節點對應數據庫表中的關聯信息,在Hibernate初始化階段,mapping節點由Hibernate自動加載到Configration和SessionFactory實例中。而屬性文件配置必須通過編碼加載映射文件。下面我們將分別對這兩種方式的使用做介紹

  1、使用Hibernate.properties屬性文件

  對於Hibernate.properties屬性文件配置,在其發佈包中的etc下,給出了此文件配置的所有屬性,初學者可以參照此文件進行配置。通過初始化Configuration實例,通過Configuration實例來加載映射文件,加載映射文件的方式有兩種,一種是通過加載資源文件的方式,一種是通過加載類的方式:如下所示:

  Configration cfg= new Configuration();

  加載資源文件方式

  cfg.addResouce("User.hbm.xml");

  加載類方式

  cfg .addClass(com.cn.User.class) ;

  通過多次執行這兩個方法可以添加更多的映射文件。因爲要通過編碼方式來加載映射文件,當項目比較大,資源很多的是時候,用此方法是件很淚奔的事情,所以不建議採用。

  2、使用Hibernate.cfg.xml文件

<!--表明以下的配置是針對session-factory配置的,SessionFactory是 Hibernate中的一個類,
這個類主要負責保存HIbernate的配置信息,以及對Session的操作-->
    <session-factory>
        <!-- hibernate.dialect 只是Hibernate使用的數據庫方言,就是要用Hibernate連接那種類型的數據庫服務器 -->
        <property name="dialect">
            org.hibernate.dialect.MySQLDialect
        </property>
        
        <!-- 設置數據庫的連接url:jdbc:mysql://localhost/hibernate,
        其中localhost表示mysql服務器名稱,此處爲本機,hibernate是數據庫名 -->
        <property name="connection.url">
            jdbc:mysql://127.0.0.1:3306/HibernateTest
        </property>
        <!-- 連接數據庫是用戶名 -->
        <property name="connection.username">root</property>
        <!-- 連接數據庫是密碼 -->
        <property name="connection.password">123456</property>
        
        <!-- 配置數據庫的驅動程序,Hibernate在連接數據庫時,需要用到數據庫的驅動程序 -->
        <property name="connection.driver_class">
            com.mysql.jdbc.Driver
        </property>
        <!-- jdbc.batch_size是指Hibernate批量插入,刪除和更新時每次操作的記錄數。BatchSize越大,
        批量操作的向數據庫發送Sql的次數越少,速度就越快,同樣耗用內存就越大 -->
        <property name="jdbc.batch_size">30</property>
        <!-- jdbc.use_scrollable_resultset是否允許Hibernate用JDBC的可滾動的結果集。
        對分頁的結果集。對分頁時的設置非常有幫助 -->
        <property name="jdbc.use_scrollable_resultset">false</property>
        <!-- jdbc.fetch_size是指Hibernate每次從數據庫中取出並放到JDBC的Statement中的記錄條數。
        FetchSize設的越大,讀數據庫的次數越少,速度越快,Fetch Size越小,讀數據庫的次數越多,速度越慢 -->
        <property name="jdbc.fetch_size">50</property>
        <!-- connection.useUnicode連接數據庫時是否使用Unicode編碼 -->
        <property name="connection.useUnicode">true</property>
        <!-- connection.characterEncoding連接數據庫時數據的傳輸字符集編碼方式,最好設置爲gbk,用gb2312有的字符不全 -->
        <property name="connection.characterEncoding">gbk</property>
        <!-- 是否自動創建數據庫表  他主要有一下幾個值:validate:當sessionFactory創建時,
        自動驗證或者schema定義導入數據庫。  create:每次啓動都drop掉原來的schema,創建新的。  create-drop:
        當sessionFactory明確關閉時,drop掉schema。update(常用):如果沒有schema就創建,有就更新。 -->
        <property name="hbm2ddl.auto">create</property>
        <!-- 數據庫連接池的大小 -->
        <property name="connection.pool_size">1</property>
        <!-- 配置此處 sessionFactory.getCurrentSession()可以完成一系列的工作,當調用時,  
        hibernate將session綁定到當前線程,事務結束後,hibernate將session從當前線程中釋放,
        並且關閉session。當再次調用getCurrentSession()時,將得到一個新的session,並重新開始這一系列工作。 -->
        <property name="current_session_context_class">thread</property>
        <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
        <property name="myeclipse.connection.profile">mysql</property>
        <!-- 是否在後臺顯示Hibernate用到的SQL語句,開發時設置爲true,便於差錯,程序運行時可以在Eclipse
        的控制檯顯示Hibernate的執行Sql語句。項目部署後可以設置爲false,提高運行效率 -->
        <property name="show_sql">true</property>
        <!-- 指定映射文件爲“om/cn/entity/User.hbm.xml -->
        <mapping resource="com/cn/entity/User.hbm.xml" />

    </session-factory>

</hibernate-configuration>

以上是Hibernate的常用配置信息,具體的其他配置信息,可以參考Hibernate的具體配置文件。我們將以current_session_context_class節點的配置信息講解,當此節點的值設置爲thread時,sessionFactory.getCurrentSession()可以完成一系列的工作,當調用時,hibernate將session綁定到當前線程,事務結束後,hibernate將session從當前線程中釋放,並且關閉session。當再次調用getCurrentSession()時,將得到一個新的session,並重新開始這一系列工作。

1、 getCurrentSession創建的session會和綁定到當前線程,而openSession不會。

2 、getCurrentSession創建的線程會在事務回滾或事物提交後自動關閉,而openSession必須手動關閉

  * 如果使用的是本地事務(jdbc事務)
 <property name="hibernate.current_session_context_class">thread</property>
 * 如果使用的是全局事務(jta事務)
 <property name="hibernate.current_session_context_class">jta</property> 

  getCurrentSession ()  使用當前的session
  openSession()         重新建立一個新的session 
應用程序中,如果DAO 層使用Spring 的hibernate 模板,通過Spring 來控制session 的生命週期,則首選getCurrentSession ()。

 使用Hibernate的大多數應用程序需要某種形式的“上下文相關的” session,特定的session在整個特定的上下文範圍內始終有效。然而,對不同類型的應用程序而言,要爲什麼是組成這種“上下文”下一個定義通常是困難的;不同的上下文對“當前”這個概念定義了不同的範圍。在3.0版本之前,使用Hibernate的程序要麼採用自行編寫的基於 ThreadLocal的上下文session,要麼採用HibernateUtil這樣的輔助類,要麼採用第三方框架(比如Spring或Pico),它們提供了基於代理(proxy)或者基於攔截器(interception)的上下文相關session。

  從3.0.1版本開始,Hibernate增加了SessionFactory.getCurrentSession()方法。一開始,它假定了採用JTA事務,JTA事務定義了當前session的範圍和上下文(scope and context)。Hibernate開發團隊堅信,因爲有好幾個獨立的JTA TransactionManager實現穩定可用,不論是否被部署到一個J2EE容器中,大多數(假若不是所有的)應用程序都應該採用JTA事務管理。基於這一點,採用JTA的上下文相關session可以滿足你一切需要。

轉自:https://www.cnblogs.com/hnlshzx/p/3486293.html

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