繁体   English   中英

无法在Spring应用程序中获得与MySQL的JDBC连接

[英]Unable to get JDBC connection in Spring application to MySQL

我在Spring中有以下数据库配置:

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
            <property name="url" value="jdbc:dburl" />
            <property name="driverClassName" value="com.mysql.jdbc.Driver" />
            <property name="username" value="username" />
            <property name="password" value="passworf" />
            <property name="removeAbandoned" value="true" />
            <property name="initialSize" value="3" />
            <property name="maxActive" value="5" />
        </bean>

用于从数据库加载属性值的附加配置。

<bean id="config1" class="org.apache.commons.configuration.DatabaseConfiguration">
        <constructor-arg type="javax.sql.DataSource" ref="dataSource" />
        <constructor-arg index="1" value="tablename1" />
        <constructor-arg index="2" value="columnname" />
        <constructor-arg index="3" value="columnvalue" />
    </bean>

    <bean id="configFactory1"
        class="org.springmodules.commons.configuration.CommonsConfigurationFactoryBean">
        <constructor-arg ref="config1" />
    </bean>

    <!-- DB Properties Initialization -->
    <bean id="configurationPlaceHolder1"
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="ignoreUnresolvablePlaceholders" value="false"/>
        <property name="properties" ref="configFactory1" />
    </bean>

    <bean id="config2" class="org.apache.commons.configuration.DatabaseConfiguration">
        <constructor-arg type="javax.sql.DataSource" ref="dataSource" />
        <constructor-arg index="1" value="tablename2" />
        <constructor-arg index="2" value="columnname" />
        <constructor-arg index="3" value="columnvalue" />
    </bean>

    <bean id="configFactory2"
        class="org.springmodules.commons.configuration.CommonsConfigurationFactoryBean">
        <constructor-arg ref="config2" />
    </bean>

    <!-- DB Properties Initialization -->
    <bean id="configurationPlaceHolder2"
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="ignoreUnresolvablePlaceholders" value="false"/>
        <property name="properties" ref="configFactory2" />
    </bean>

DAO配置出现问题:

    <!-- DAO Bean which is causing issue -->
    <bean id="problematicBean" class="com.example.ProblematicDAOImpl" scope="singleton">
      <property name="dataSource"  ref="dataSource" />    
    </bean>

当我启动应用程序时,我停留在以下行:

    17 Feb 2014 15:39:58,981 -  main - DEBUG - 
org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:691)  - 
Executing prepared SQL query
            17 Feb 2014 15:39:58,983 -  main - DEBUG - 
org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:625)  - 
Executing prepared SQL statement [ SQL STATEMENT ]  


17 Feb 2014 15:39:59,000 -  main - DEBUG -
 org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:110)  
- Fetching JDBC Connection from DataSource

此行之后,应用程序挂起并且不响应。 它也不会引发异常。

我已经做了以下检查:

  • 增加了maxActive值。
  • 增加的initialSize值。
  • Query Browser正在执行Checked - SQL STATEMENT

**更新**

我进一步调试了代​​码,代码在方法org.springframework.jdbc.core.JdbcTemplate.execute(PreparedStatementCreator, PreparedStatementCallback<T>) org.springframework.jdbc.core.JdbcTemplate挂起@line 642

代码行如下:

if (this.nativeJdbcExtractor != null) {
                psToUse = this.nativeJdbcExtractor.getNativePreparedStatement(ps);
            }
            T result = action.doInPreparedStatement(psToUse);//Hangs at this line
            handleWarnings(ps);
            return result;

我你有。 它解决了我自己。 我正在使用NamedParameterJdbctemplate来调用没有任何参数的查询。 spring api执行准备好的语句时,此操作挂起。 我将其切换为JdbcTempalte类。 工作正常。

请检查您的JRE版本,因为在几个JRE-1.6.x版本上Microsoft jdbc驱动程序已损坏,导致线程挂起。 以下是更多详细信息: -http : //bugs.java.com/bugdatabase/view_bug.do?bug_id=7105007

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM