PropertyPlaceholderConfigurer的用法

链接:http://www.cnblogs.com/wanggd/archive/2013/07/04/3172042.html

用法1:

         xmlns="http://www.springframework.org/schema/beans"

         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

         xmlns:p="http://www.springframework.org/schema/p"

         xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

 

        

                  

                           

                                    

  1. 这里的classpath可以认为是项目中的src-
  2. 属性名是 locations,使用子标签可以指定多个数据库的配置文件,这里指定了一个

->

                                     classpath:resource/config/jdbc.properties

                           

                  

        

此时的数据库配置文件项目路径是这样的

PropertyPlaceholderConfigurer的用法_第1张图片

用法2:

读取数据库的配置文件还可以使用下面的方式

"1.0" encoding="UTF-8"?>

 

"http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd"

  "propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

    "locations">

     

         /WEB-INF/config_test/jdbc.properties

     

   

 

此时jdbc.properties文件的位置如下图所示

.properties配置文件还可以有多个,这里在标签中指定了2个数据的配置文件

"1.0" encoding="UTF-8"?>

 "http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd"

  "propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

    "locations">

     

        classpath:jdbc.properties

        /WEB-INF/config_test/jdbc.properties

     

   

 

classpath:jdbc.properties对应的文件位置是:

PropertyPlaceholderConfigurer的用法_第2张图片

文件内容是:配置的是sqlserver的连接信息

sqlserver.username=sa

sqlserver.password=sqlserver

sqlserver.url=jdbc\:jtds\:sqlserver\://localhost\:1433/J2EE

sqlserver.driver=net.sourceforge.jtds.jdbc.Driver

 /WEB-INF/config_test/jdbc.properties对应的文件位置是

文件内容是:配置的是oracle的连接信息

jdbc.driverClassName=oracle.jdbc.driver.OracleDriver

jdbc.url=jdbc:oracle:thin:@127.0.0.1:1521:orcl

jdbc.username=jxbms

jdbc.password=jxbms

 这样数据库的配置信息被读取之后,在创建datasource的时候就可以使用了

 下面连接oracle 使用apache的dbcp 数据源

"dataSource"

       class="org.apache.commons.dbcp.BasicDataSource"

       destroy-method="close">

       "driverClassName">

           ${jdbc.driverClassName}

      

       "url">

           ${jdbc.url}

      

       "username">

           ${jdbc.username}

      

       "password">

           ${jdbc.password}

      

       "maxActive">

           100

      

       "maxIdle">

           3

      

       "maxWait">

           -1

      

       "defaultAutoCommit">

        false

       

   

 下面连接sqlserver数据库使用的是c3p0数据源

"dataSource_oracle" class="com.mchange.v2.c3p0.ComboPooledDataSource"

        destroy-method="close" >

        "driverClass" value="${jdbc.driverClassName}" />

        "jdbcUrl" value="${jdbc.url}" />

        "user" value="${jdbc.username}" />

        "password"  value="${jdbc.password}" />

 使用dbcp数据源令人郁闷的事,使用dbcp和spring提供的JdbcTemplate操作数据库是  查询是可以的

但是执行update、delete、insert into 操作时,数据库中的数据没有变化

 从网上查询了很多的资料,都无果。最后偶然看到网上有人说,dbcp数据源的事务不会自动提交,

当改成c3p0数据源后好了

 随后认为这下终于可以松口气了,谁知道天不遂人愿。当更换一张表进行测试,数据库中的数据还是没有变化,难道c3p0数据源也不好使,

当再次经过代码的折磨之后,

最终发现改动测试java文件,不在一个项目中,把其他的项目关闭就好了

 当文档写到这里时,突然发现oracle使用的dbcp数据源有这一项配置

        "defaultAutoCommit">

        false

       

原来dbcp数据源事务的自动提交功能被关闭了

 马上把事务自动提交改成true  进行测试,一切ok,(^ _ ^)


你可能感兴趣的:(服务器相关)