spring - 如何使用 Spring 为 HikariCP 设置数据源?

标签 spring jdbc spring-jdbc jdbctemplate hikaricp

您好,我正在尝试将 HikariCP 与 Spring 一起用于连接池。我正在使用 jdbcTempLate 和 JdbcdaoSupport。
这是我的数据源 Spring 配置文件:

<bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource">
    <property name="dataSourceClassName" value="oracle.jdbc.driver.OracleDriver"/>
    <property name="dataSource.url" value="jdbc:oracle:thin:@localhost:1521:XE"/>
    <property name="dataSource.user" value="username"/>
    <property name="dataSource.password" value="password"/>
</bean>

但不幸的是,正在生成以下错误消息:

Cannot resolve reference to bean 'dataSource' while setting bean property 'dataSource'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in ServletContext resource [/WEB-INF/dispatcher-servlet.xml]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [com.zaxxer.hikari.HikariDataSource]: No default constructor found; nested exception is java.lang.NoSuchMethodException: com.zaxxer.hikari.HikariDataSource.<init>()

谁能告诉我如何解决这个问题?

最佳答案

你需要在你的 bean 配置上写下这个结构(这是你的数据源):

<bean id="hikariConfig" class="com.zaxxer.hikari.HikariConfig">
    <property name="poolName" value="springHikariCP" />
    <property name="connectionTestQuery" value="SELECT 1" />
    <property name="dataSourceClassName" value="${hibernate.dataSourceClassName}" />
    <property name="maximumPoolSize" value="${hibernate.hikari.maximumPoolSize}" />
    <property name="idleTimeout" value="${hibernate.hikari.idleTimeout}" />

    <property name="dataSourceProperties">
        <props>
            <prop key="url">${dataSource.url}</prop>
            <prop key="user">${dataSource.username}</prop>
            <prop key="password">${dataSource.password}</prop>
        </props>
    </property>
</bean>

<!-- HikariCP configuration -->
<bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource" destroy-method="close">
    <constructor-arg ref="hikariConfig" />
</bean>

这是我的例子,它正在工作。您只需将您的属性放在 hibernate.properties 上并在之前设置:

<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations">
        <list>
            <value>classpath:hibernate.properties</value>
        </list>
    </property>
</bean>

Obs.:版本是
log4j:1.2.16
springframework:3.1.4.RELEASE
HikariCP:1.4.0

属性文件(hibernate.properties):

hibernate.dataSourceClassName=oracle.jdbc.pool.OracleDataSource
hibernate.hikari.maximumPoolSize=10
hibernate.hikari.idleTimeout=30000
dataSource.url=jdbc:oracle:thin:@localhost:1521:xe
dataSource.username=admin
dataSource.password=

关于spring - 如何使用 Spring 为 HikariCP 设置数据源?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23172643/

相关文章:

java - 无法将类型 'java.util.ArrayList' 的属性值转换为所需类型 'javax.xml.ws.handler.HandlerResolver'

java - 如何在我的 WebContent 文件夹中获取文件的真实路径?

mysql - 无法从 Eclipse 连接到 MySql 数据库 : java/sql/SQLException

oracle - 旧式外连接 (+) 不能与 ANSI 连接一起使用,Oracle 数据库错误代码 ORA-25156

mysql - 连接已经关闭

当 https 端口被 http 请求命中时,Spring boot 禁用响应

java - 从 python/django 学习 java/spring

mysql - 为什么需要将表(在 MySQL 中)中的至少一列指定为 PRIMARY KEY,以便表通过 JDBC 接受 UPDATE 和 INSERT 语句?

java - JDBC 自定义类型映射顺序问题

java - 类型集合的 toArray 方法未定义