现在的位置: 首页 > 综合 > 正文

org.hibernate.exception.JDBCConnectionException: could not execute query

2014年03月03日 ⁄ 综合 ⁄ 共 2898字 ⁄ 字号 评论关闭

   

MySQL的有效连接时间为8个小时,如果一个连接8小时没有请求和操作,就会自动断开(即使修改了MySQL连接的有效时间,问题在这里无法得到根本解决);而Hibernate中并没有配置连接池,使用的是它自带的也就是DriverManagerConnectionProvider。而这个连接池不支持在分配一个连接时,测试其有效与否的功能(不过根据异常提示可以再Jdbc连接的URL中加入属性'autoReconnect=true'),因此这个连接池并不知道它所管理的连接中是否有被MySQL断开的。如果一个程序要使用数据库连接,而Hibernte的连接池分配一个已经被MySQL断开了的给程序使用,那么便会出现错误。

我查了一下Hibernate支持如下的连接池:

1.DriverManagerConnectionProvider:代表由Hibernate提供的默认的数据库连接池 

2.C3P0ConnectionProvider:代表C3P0连接池

3.ProxoolConnectionProvider:代表Proxool连接池

4.DBCPConnectionProvider:代表DBCP连接池

其他3个数据连接池都提供检查连接是否有效的功能,正好是可以解决上面的问题。这里我采用C3P0连接池(Hibernate文档中推荐的),首先导入C3P0的Jar包(c3p0.jar),再在Hibernate配置中加入:

<property name="hibernate.connection.provider_class">

               org.hibernate.connection.C3P0ConnectionProvider

            </property>

            <property name="c3p0.acquire_increment">1</property>

            <property name="c3p0.idle_test_period">300</property>

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

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

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

            <property name="c3p0.timeout">90</property>

            <property name="c3p0.preferredTestQuery ">select 1 from user where id=1</property>

            <property name="c3p0.idleConnectionTestPeriod ">18000</property>           

           <property name="c3p0.maxIdleTime">25000</property>         

           <property name="c3p0.testConnectionOnCheckout">true</property>

Proxool连接池的配置方法:

1、Hibernate配置文件:

<session-factory>

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

<property name="hibernate.proxool.xml">proxool.xml</property>

<property name="hibernate.proxool.pool_alias">mysql</property>

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

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

<mapping resource="com/lab1000/jcom/pojo/Admin.hbm.xml">

...

</session-factory>

  其中各属性含义如下:

hibernate.connection.provider_class:指明使用Proxool连接池

hibernate.proxool.xml:指明Proxool配置文件所在位置,这里与Hibernate的配置文件在同一目录下

hibernate.proxool.pool_alias:指明要使用的proxool.xml中定义的proxool别名

  2、Proxool配置文件(proxool.xml):

<something-else-entirely>

<proxool>

<alias>mysql</alias>

<driver-url>

jdbc:mysql://localhost/yourDatebase?useUnicode=true&characterEncoding=UTF-8

</driver-url>

<driver-class>com.mysql.jdbc.Driver</driver-class>

<driver-properties>

<property name="user" value="root">

<property name="password" value="password">

</driver-properties>

<house-keeping-sleep-time>90000</house-keeping-sleep-time>

<maximum-new-connections>20</maximum-new-connections>

<prototype-count>3</prototype-count>

<maximum-connection-count>20</maximum-connection-count>

<minimum-connection-count>3</minimum-connection-count>

<test-before-use>true</test-before-use>

<test-after-use>true</test-after-use>

<house-keeping-test-sql>SELECT CURRENT_USER</house-keeping-test-sql>

</proxool>

</something-else-entirely>

  3、下载和安装Proxool的包文件

  下载地址:http://proxool.sourceforge.net/download.html

抱歉!评论已关闭.