Spring在第三方依赖包中包含了两个数据源的实现类包,其一是Apache的DBC,其二是 C3P0.可以在Spring配置文件中利用这两者中任何一个配置数据源.
这主要说明DBCP.
DBCP的官方主页在:
http://commons.apache.org/dbcp/
也可以通过maven直接搜索 commons-dbcp.
需要注意的是目前DBCP有2个版本:1.4和1.3.
* DBCP 1.4 compiles and runs under JDK 1.6 only (JDBC 4)
* DBCP 1.3 compiles and runs under JDK 1.4-1.5 only (JDBC 3)
所以请注意自己的JDK版本,下载对应的DBCP.
JDK1.6的下载1.4.
JDK1.4-1.5的 下载1.3版本.
最基本的配置:
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3309/demo" />
<property name="username" value="root" />
<property name="password" value="root" />
</bean>
BasicDataSource提供了close()方法关闭数据源,所以必须设定
destroy-method="close"
属性, 以便Spring容器关闭时,数据源能够正常关闭.
如果没有这个属性,则会报类似
"Couldn't find a destroy method named 'close' on bean with name 'dataSource'"的错误.
还有一些可选属性:
defaultAutoCommit:设置从数据源中返回的连接是否采用自动提交机制,默认值为 true;
defaultReadOnly:设置数据源是否仅能执行只读操作, 默认值为 false;
maxActive:最大连接数据库连接数,设置为0时,表示没有限制;
maxIdle:最大等待连接中的数量,设置为0时,表示没有限制;
maxWait:最大等待秒数,单位为毫秒, 超过时间会报出错误信息;
validationQuery:用于验证连接是否成功的查询SQL语句,SQL语句必须至少要返回一行数据, 如你可以简单地设置为:“select 1 ”;
removeAbandoned:是否自我中断,默认是 false ;
removeAbandonedTimeout:几秒后数据连接会自动断开,在removeAbandoned为true,提供该值;
logAbandoned:是否记录中断事件, 默认为 false;
引用jdbc.properties文件后,可以配置成如下
spring配置文件
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>/WEB-INF/jdbc.properties</value>
</list>
</property>
</bean>
<!-- 数据源配置,使用应用内的DBCP数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<!-- Connection Info -->
<property name="driverClassName" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="maxActive" value="${jdbc.maxActive}" />
<property name="maxIdle" value="${jdbc.maxIdle}" />
<property name="maxWait" value="${jdbc.maxWait}" />
<property name="defaultAutoCommit" value="false" />
<property name="validationQuery" value="select 1" />
<property name="testOnBorrow" value="true" />
</bean>
jdbc.properties配置文件
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://127.0.0.1/demo?zeroDateTimeBehavior\=convertToNull&characterEncoding\=utf-8
jdbc.username=root
jdbc.password=root
jdbc.maxActive=20
jdbc.maxIdle=10
jdbc.maxWait=4000
分享到:
相关推荐
Spring_c3p0与dbcp数据源_的配置.doc 很不错的哦!拿出来和大家一起学习!
dbcp数据源配置JAR包
配置DBCP数据源必备的jar包: 1.commons-dbcp-1.4.jar 2.commons-pool-1.6.jar 给大家分享一下!
dbcp 的 基 本 数 据 源 类的配置方法,
配置dbcp数据源的必要的jar包,非常好用!
打包好的DBCP配置相关jar包,配置DBCP时会很有用,包含commons-dbcp.jar与commons-pool.jar
NULL 博文链接:https://gary-bu.iteye.com/blog/2024022
数据库配置数据源所需 数据库配置数据源所需 数据库配置数据源所需 数据库配置数据源所需
里面包含commons-dbcp.jar,commons-pool.jar2个jar包。配置的时候把jar包复制到相应目录即可。
apache基金会的开源数据源dbcp的基本配置
DBCP基本配置参数说明,详细介绍了dbcp的各个配置参数及作用
在Spring3中配置数据源,包括DBCP,C3P0,Proxool,Bonecp主要的数据源,里面包含这些数据源的jar文件和依赖文件及配置文件。。 如Bonecp目前听说是最快的数据源,速度是传统的c3p0的25倍, bonecp.properties文件: ...
DBCP连接池DBCP和C3P0配置,可以对数据源进行各种有效的控制
用dbcp连接池,mysql数据库,在tomcat服务器下,通过hibernate配置jndi数据源. 我想此标题已经比较明确了。 在此说明一点,hibernate开发小组不推荐在hibernate下使用dbcp,如果一定要的话,请慎重考虑。
技术分享:Spring的数据源配置 DBCP、C3P0、JNDI
技术分享:Spring的数据源配置 DBCP、C3P0、BoneCP、JNDI
TOMCAT连接池DBCP,在server.xml中配置全局数据源详细的介绍,很有好用啊!!
NULL 博文链接:https://sailinglee.iteye.com/blog/480715
apache 数据源(dbcp)资源包,此包应用于spring的application.xml文件对数据源配置的资源包。 比较难找、但有一点:绝不能要分数--毕竟非稀有特色资源。 看到很多人要分、痛恨!!!!
技术分享:配置Spring数据源c3p0与dbcp