0

最近我决定从 Common DBCP 迁移到 Tomcat JDBC Connection Pool。我更改了 bean 描述(使用 spring 3.1 + hibernate 4 + tomcat)并且在我的 web 应用程序启动时遇到了下一个问题:

HHH000342:无法获得查询元数据的连接:com.mysql.jdbc.Driver

然后当我尝试从我的应用程序中查询 db 时,我得到:

23:04:40,021 WARN [http-bio-8080-exec-10] spi.SqlExceptionHelper:(SqlExceptionHelper.java:143) - SQL 错误:0,SQLState:null

23:04:40,022 错误 [http-bio-8080-exec-10] spi.SqlExceptionHelper:(SqlExceptionHelper.java:144) - com.mysql.jdbc.Driver

我一定是在配置上做错了,所以休眠无法获得连接但看不到它。如果你能指出我正确的方向,我真的很感激。

这是我的数据源 bean 定义的一部分

<bean id="jdbcDataSource" class="org.apache.tomcat.jdbc.pool.DataSource" destroy-              method="close"    
    p:driverClassName="com.mysql.jdbc.Driver"
p:url="jdbc:mysql://127.0.0.1:3306/test"
p:username="root"
p:password="test" 
p:defaultAutoCommit="false"
p:maxActive="100"
p:maxIdle="100"
    p:minIdle="10"
p:initialSize="10"
p:maxWait="30000"
p:testWhileIdle="true"   
p:validationInterval="60000"
p:validationQuery="SELECT 1"                
p:timeBetweenEvictionRunsMillis="60000"
p:minEvictableIdleTimeMillis="600000"
p:maxAge="360000"
/>

这就是我将它与春天的会话工厂联系起来的方式

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="jdbcDataSource" />...
4

2 回答 2

0

确保您使用的是 JDK 6。使用 JDK5 可能是导致此错误的原因之一。

但是,您的问题有一种解决方法,在此处进行了说明

于 2012-05-06T21:31:53.380 回答
0

迁移后,我忘记将 lib tomcat-jdbc 添加到我的类路径:) 现在它可以工作了

于 2012-05-07T04:37:59.007 回答