Java JPA Connection Pool

摘要:Java JPA Connection Pool

在Java要導入JPA Connection Pool

需在Persistence.xml加入

以下內容,此例以mysql、hibernate相關為主的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="local" transaction-type="RESOURCE_LOCAL">
  <provider>org.hibernate.ejb.HibernatePersistence</provider>
  <properties>
   <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/mysqldatabase" />
   <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
   <property name="hibernate.connection.username" value="root" />
   <property name="hibernate.connection.password" value="" />

        <!-- Important -->
        <property name="hibernate.connection.provider_class"
          value="org.hibernate.connection.C3P0ConnectionProvider" />

        <property name="hibernate.c3p0.max_size" value="4" />
        <property name="hibernate.c3p0.min_size" value="1" />
        <property name="hibernate.c3p0.acquire_increment" value="3" />
        <property name="hibernate.c3p0.idle_test_period" value="60" />
        <property name="hibernate.c3p0.max_statements" value="0" />
        <property name="hibernate.c3p0.timeout" value="1800" />

  </properties>
 </persistence-unit>
</persistence>


 

加入這個需注意需要C3P0ConnectionProvider所用的jar檔, 所以要上網找 http://sourceforge.net/projects/c3p0/

掛載裡面的c3p0-0.9.1.2.jar就可以執行

使用了Connection Pool發現他的好處,

大概是如果你有多執行緒的話,這樣開不同執行緒後,可以管理你的總共使用連線數,就算沒有使用的話,也會關掉連線,而不用一直掛載者。

如果是用原本的寫法,大概,不是用一個靜態的類別去單獨使用的話,(就是只有一條線)就是每次需要時呼叫,(就變成無上限的呼叫),

或則會忘了結束連線等這些麻煩。

這是開發中發現早期只有寫mysqlJDCB及用JPA來做時,所感覺到方便的地方。