Hibernate配置文件主要功能是配置數據庫連接和Hibernate運行時所需的各種屬性,配置文件應該位 於JAVA應用或者JAVA Web應用的類文件中,剛開始接觸Hibernate的時候,感覺Hibernate的配置既繁瑣有 麻煩,不知道童鞋們在學習Hibernate的時候有沒有這種感覺,是不是還在懷念用JDBC連接數據庫呢,但 是繁瑣背後隱藏著巨大的價值,下面我們將帶你一探配置背後的奧秘。
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文件
<!--標准的XML文件的起始行,version='1.0'表明XML的版本,encoding='gb2312'表 明XML文件的編
碼方式-->
<!--表明解析本XML文件的DTD文檔位置,DTD是DocumentType Definition 的縮寫, 即文檔類型的定
義,
XML解析器使用DTD文檔來檢查XML文件的合法性。 /hibernate.sourceforge.net/hibernate-
configuration-3.0dtd
可以在Hibernate3.1.3軟件包中的src\org\hibernate目錄中找到此文件-->
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!--聲明Hibernate配置文件的開始-->
<hibernate-configuration>
<!--表明以下的配置是針對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必須手動關閉
這裡getCurrentSession本地事務(本地事務:jdbc)時 要在配置文件裡進行如下設置
* 如果使用的是本地事務(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可 以滿足你一切需要。
最後附上一份從不同層面看Hiberenate的框架圖


接下來的文章,我們將一步一步對Hibernate方方面面進行全面解析。
查看本欄目