使用DBCP进行数据源配置
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版本.
最基本的配置:
1. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
2. "close">
3. "driverClassName" value="com.mysql.jdbc.Driver" />
4. "url" value="jdbc:mysql://localhost:3309/demo" />
5. "username" value="root" />
6. "password" value="root" />
7. </bean>
BasicDataSource提供了close()方法关闭
数据
源,所以必须设定
1. 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
配置
文件
1. <bean id="propertyConfigurer"
2. class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
3. "locations">
4. <list>
5. <value>/WEB-INF/jdbc.properties</value>
6. </list>
7. </property>
8. </bean>
9.
10. <!-- <strong>数据</strong>源<strong>配置</strong>,使用<strong>应用</strong>内的DBCP<strong>数据</strong>库连接池 -->
11. "dataSource" class="org.apache.commons.dbcp.BasicDataSource"
12. "close">
13. <!-- Connection Info -->
14. "driverClassName" value="${jdbc.driverClassName}" />
15. "url" value="${jdbc.url}" />
16. "username" value="${jdbc.username}" />
17. "password" value="${jdbc.password}" />
18. "maxActive" value="${jdbc.maxActive}" />
19. "maxIdle" value="${jdbc.maxIdle}" />
20. "maxWait" value="${jdbc.maxWait}" />
21. "defaultAutoCommit" value="false" />
22. "validationQuery" value="select 1" />
23. "testOnBorrow" value="true" />
24. </bean>jdbc.properties
配置
文件
1. jdbc.driverClassName=com.mysql.jdbc.Driver
2. jdbc.url=jdbc\:mysql\://127.0.0.1/demo?zeroDateTimeBehavior\=convertToNull&characterEncoding\=utf-8
3. jdbc.username=root
4. jdbc.password=root
5. jdbc.maxActive=20
6. jdbc.maxIdle=10
7. jdbc.maxWait=4000
















