Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/388.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Hibernate MySQL Windows无法';t断开连接_Java_Mysql_Hibernate - Fatal编程技术网

Java Hibernate MySQL Windows无法';t断开连接

Java Hibernate MySQL Windows无法';t断开连接,java,mysql,hibernate,Java,Mysql,Hibernate,我开发了一个Java应用程序,它使用Hibernate连接到MySQL数据库。使用Mac OS X时,该应用程序工作正常,但如果我尝试在Windows(XP)下使用它,则会出现以下错误: Exception in thread "main" org.hibernate.exception.GenericJDBCException: Could not open connection at org.hibernate.exception.internal.StandardSQLEx

我开发了一个Java应用程序,它使用Hibernate连接到MySQL数据库。使用Mac OS X时,该应用程序工作正常,但如果我尝试在Windows(XP)下使用它,则会出现以下错误:

    Exception in thread "main" org.hibernate.exception.GenericJDBCException: Could not open connection
    at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:54)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:125)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:110)
    at org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:304)
    at org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.getConnection(LogicalConnectionImpl.java:169)
    at org.hibernate.engine.transaction.internal.jdbc.JdbcTransaction.doBegin(JdbcTransaction.java:67)
    at org.hibernate.engine.transaction.spi.AbstractTransactionImpl.begin(AbstractTransactionImpl.java:160)
    at org.hibernate.internal.SessionImpl.beginTransaction(SessionImpl.java:1395)
    at persistence.Axdbv4HibernateManager.getNRecords(Axdbv4HibernateManager.java:51)
    at manager.Phase1.startPhase1(Phase1.java:28)
    at manager.Phase1.main(Phase1.java:89)
    at manager.Main.main(Main.java:60)
Caused by: java.sql.SQLException: Connections could not be acquired from the underlying database!
    at com.mchange.v2.sql.SqlUtils.toSQLException(SqlUtils.java:106)
    at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:677)
    at com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource.getConnection(AbstractPoolBackedDataSource.java:128)
    at org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider.getConnection(C3P0ConnectionProvider.java:79)
    at org.hibernate.internal.AbstractSessionImpl$NonContextualJdbcConnectionAccess.obtainConnection(AbstractSessionImpl.java:292)
    at org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:297)
    ... 8 more
Caused by: com.mchange.v2.resourcepool.CannotAcquireResourceException: A ResourcePool could not acquire a resource from its primary factory or source.
    at com.mchange.v2.resourcepool.BasicResourcePool.awaitAvailable(BasicResourcePool.java:1406)
    at com.mchange.v2.resourcepool.BasicResourcePool.prelimCheckoutResource(BasicResourcePool.java:594)
    at com.mchange.v2.resourcepool.BasicResourcePool.checkoutResource(BasicResourcePool.java:514)
    at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutAndMarkConnectionInUse(C3P0PooledConnectionPool.java:743)
    at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:670)
    ... 12 more
这是我的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-configuration>

<session-factory>

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

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

<property name="hibernate.connection.url">jdbc:mysql://localhost/axdbv4</property>

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

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

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

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

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

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

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

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

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

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

<mapping resource="domain/DcmiRecord.hbm.xml" />

<mapping resource="domain/OccurrenceNameRecord.hbm.xml" />

<mapping resource="domain/OptionalFieldRecord.hbm.xml" />

<mapping resource="domain/RepresentationsNamesRecord.hbm.xml" />

<mapping resource="domain/NIDInfoRecord.hbm.xml" />

</session-factory>

</hibernate-configuration>

com.mysql.jdbc.Driver
org.hibernate.dialogue.mysqldialogue
jdbc:mysql://localhost/axdbv4
根
我的密码
org.hibernate.connection.C3P0ConnectionProvider
1.
300
30
50
100
100
5.
我已经尝试使用连接数据库

mysql-u root-h localhost-p mypassword

而且效果很好。 有人知道怎么处理吗? 谢谢

好了,我终于解决了! 问题在于连接过程中使用的编码。我的数据库使用UTF-8,但默认情况下Hibernate使用拉丁语-1。因此,有必要将以下属性添加到hibernate.cfg.xml文件中:

<property key="hibernate.connection.characterEncoding">UTF-8</property>
<property key="hibernate.connection.useUnicode">true</property>
UTF-8
真的

堆栈跟踪表明您的问题出在C3P0上。@duffymo看起来连接池已耗尽(已达到最大连接数)是的,这是真的,但我不知道出了什么问题。正如我所说的,使用OSXView this,同样的配置也可以正常工作:不。我还设置了c3p0 maxPoolSize和minPoolSize属性,但它不起作用。。。。