hibernate配置連接池

Hibernate支持第三方的連接池,官方推薦的連接池是C3P0,Proxool,以及DBCP。在配置連接池時需要注意的有三點:

一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已經不再推薦使用,官方的解釋是這個連接池存在缺陷。如果你因爲某種原因需要在Hibernate3中使用DBCP,建議採用JNDI方式。

二、默認情況下(即沒有配置連接池的情況下),Hibernate會採用內建的連接池。但這個連接池性能不佳,且存在諸多BUG,因此官方也只是建議僅在開發環境下使用。

三、Hibernate2和Hibernate3的命名空間有所變化。例如,配置C3P0時的provider_class有Hibernate2環境下使用net.sf.hibernate.connection.C3P0ConnectionProvider,在Hibernate3環境下使用org.hibernate.connection.C3P0ConnectionProvider。
在hibernate.cfg.xml中配置c3po的屬性有:

       <property name="hibernate.c3p0.max_size">20</property>

        <!-- 最小連接數 -->
        <property name="hibernate.c3p0.min_size">5</property>

        <!-- 獲得連接的超時時間,如果超過這個時間,會拋出異常,單位毫秒 -->
        <property name="hibernate.c3p0.timeout">120</property>

        <!-- 最大的PreparedStatement的數量 -->
        <property name="hibernate.c3p0.max_statements">100</property>

        <!-- 每隔120秒檢查連接池裏的空閒連接 ,單位是秒-->
        <property name="hibernate.c3p0.idle_test_period">120</property>

        <!-- 當連接池裏面的連接用完的時候,C3P0一下獲取的新的連接數 -->
        <property name="hibernate.c3p0.acquire_increment">2</property>

        <!-- 每次都驗證連接是否可用 -->
        <property name="hibernate.c3p0.validate">true</property>

 

給出一個完整的配置文件:

<?xml version='1.0' encoding='UTF-8'?>

<!DOCTYPE hibernate-configuration

PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"

"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

 

<hibernate-configuration>

<session-factory >

 

<!—JDBC驅動程序-->

<property name="connection.driver_class">com.mysql.jdbc.Driver</property>

 

<!-- 連接數據庫的URL-->

<property name="connection.url">

jdbc:mysql://localhost:3306/schoolproject

</property>

<property name="connection.useUnicode">true</property>

<property name="connection.characterEncoding">UTF-8</property>

 

<!--連接的登錄名-->

<property name="connection.username">root</property>

 

<!--登錄密碼-->

<property name="connection.password"></property>

 


 

<!-- C3P0連接池設定-->

<p
<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider
</property>

<property name="hibernate.c3p0.max_size">20</property>

<property name="hibernate.c3p0.min_size">5</property>

<property name="hibernate.c3p0.timeout">120</property>

<property name="hibernate.c3p0.max_statements">100</property>

<property name="hibernate.c3p0.idle_test_period">120</property>

<property name="hibernate.c3p0.acquire_increment">2</property>

 

<!--是否將運行期生成的SQL輸出到日誌以供調試-->

<property name="show_sql">true</property>

 

<!--指定連接的語言-->

<property name="dialect">org.hibernate.dialect.MySQLDialect</property>

 

<!--映射Student這個資源-->

<mapping resource="com/wqbi/model/pojo/student.hbm.xml" />

 

</session-factory>

 

</hibernate-configuration>

 

Hiberante使用JNDI連接池:

JNDI連接池,數據源已經由應用服務配置好(如Web服務器),Hibernate需要做的只是通過JNDI名查找到此數據源。應用服務器將連接池對外顯示爲JNDI綁定數據源,它是javax.jdbc.Datasource類的一個實例。只要配置一個Hibernate文件,如:

hibernate.connection.datasource=java:/comp/env/jdbc/schoolproject //JNDI名

hibernate.transaction.factory_class = org.hibernate.transaction.JTATransactionFactory

hibernate.transaction.manager_loopup_class =

org.hibernate.transaction.JBossTransactionManagerLookup

hibernate.dialect=org.hibernate.dialect.MySQLDialect

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章