使用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