第一种:beans.xml

  1. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  2. destroy-method="close">
  3. <property name="driverClassName" value="com.microsoft.sqlserver.jdbc.SQLServerDriver" />
  4. <property name="url"
  5. value="jdbc:sqlserver://localhost:1433;DatabaseName=spring" />
  6. <property name="username" value="sa" />
  7. <property name="password" value="********" />
  8. </bean>

第二种:beans.xml 
    <bean id="mappings"

  1. class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  2. <property name="locations" value="classpath:jdbc.properties"></property>
  3. </bean>
  4. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  5. destroy-method="close">
  6. <property name="driverClassName" value="${jdbc.driverClassName}" />
  7. <property name="url" value="${jdbc.url}" />
  8. <property name="username" value="${jdbc.username}" />
  9. <property name="password" value="${jdbc.password}" />
  10. </bean>

在src文件夹里新建一个jdbc.properties文件,里面的内容为如下:

  1. jdbc.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
  2. jdbcjdbc.url=jdbc:sqlserver://localhost:1433;DatabaseName=spring
  3. jdbc.username=sa
  4. jdbc.password=********

第三种: 
beans.xml

  1. <bean id="mappings"
  2. class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  3. <property name="locations" value="classpath:jdbc.properties"></property>
  4. </bean>
  5. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  6. destroy-method="close">
  7. <property name="driverClassName" value="${jdbc.driverClassName}" />
  8. <property name="url" value="${jdbc.url}" />
  9. <property name="username" value="${jdbc.username}" />
  10. <property name="password" value="${jdbc.password}" />
  11. </bean>
  12. <context:property-placeholder location="classpath:jdbc.properties" />在src文件夹里新建一个jdbc.properties文件,里面的内容为如下:
  13. jdbc.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
  14. jdbcjdbc.url=jdbc:sqlserver://localhost:1433;DatabaseName=spring
  15. jdbc.username=sa
  16. jdbc.password=********

其中第二种与第三种类似,只是指定配置文件的方法不一样。 
第四种: 
beans.xml

  1. <bean id="mappings"
  2. class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  3. <!-- typed as a java.util.Properties -->
  4. <property name="properties">
  5. <value>
  6. jdbc.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
  7. jdbcjdbc.url=jdbc:sqlserver://localhost:1433;DatabaseName=spring
  8. jdbc.username=sa
  9. jdbc.password=********
  10. </value>
  11. </property>
  12. </bean>
  13. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  14. destroy-method="close">
  15. <property name="driverClassName" value="${jdbc.driverClassName}" />
  16. <property name="url" value="${jdbc.url}" />
  17. <property name="username" value="${jdbc.username}" />
  18. <property name="password" value="${jdbc.password}" />
  19. </bean>

第五种:

  1. beans.xml
  2. <bean id="myDataSource" class="org.apache.commons.dbcp.BasicDataSource"
  3. destroy-method="close"
  4. p:driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
  5. p:url="jdbc:sqlserver://localhost:1433;DatabaseName=spring"
  6. p:username="sa"
  7. p:password="********"/>

再加上命名空间:

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

性能参数要根据实际情况测试得来的数据确定如何配置。 
转自:http://www.cppblog.com/fenglin/articles/130494.html 

第六种,在网上看到 

  Spring中提供了一种简便的方式就是context:property-placeholder/元素 
只需要在spring的配置文件里添加一句

  1. <context:property-placeholder location="classpath:jdbc.properties"/>

即可,这里location值为参数配置文件的位置,参数配置文件通常放在src目录下,而参数配置文件的格式跟java通用的参数配置文件相同,即键值对的形式,例如: 
#jdbc配置

  1. test.jdbc.driverClassName=com.mysql.jdbc.Driver
  2. test.jdbc.url=jdbc:mysql://localhost:3306/test
  3. test.jdbc.username=root
  4. test.jdbc.password=root

行内#号后面部分为注释 
应用: 
1.这样一来就可以为spring配置的bean的属性设置值了,比如spring有一个jdbc数据源的类DriverManagerDataSource 
在配置文件里这么定义bean:

  1. <bean id="testDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  2. <property name="driverClassName" value="${test.jdbc.driverClassName}"/>
  3. <property name="url" value="${test.jdbc.url}"/>
  4. <property name="username" value="${test.jdbc.username}"/>
  5. <property name="password" value="${test.jdbc.password}"/>
  6. </bean>

注意配置文件中

<bean id="accountDao" class="my.dao.impl.AccountDaoImpl">
  <property name="dataSource" ref="dataSource"/>
</bean>

2.甚至可以将${ }这种形式的变量用在spring提供的注解当中,为注解的属性提供值 
外在化应用参数的配置 

在开发企业应用期间,或者在将企业应用部署到生产环境时,应用依赖的很多参数信息往往需要调整,比如LDAP连接、RDBMS JDBC连接信息。对这类信息进行外在化管理显得格外重要。PropertyPlaceholderConfigurer和PropertyOverrideConfigurer对象,它们正是担负着外在化配置应用参数的重任。 

  <context:property-placeholder/>元素 
PropertyPlaceholderConfigurer实现了BeanFactoryPostProcessor接口,它能够对<bean/>中的属性值进行外在化管理。开发者可以提供单独的属性文件来管理相关属性。比如,存在如下属性文件,摘自userinfo.properties。

  1. db.username=scott
  2. db.password=tiger

如下内容摘自propertyplaceholderconfigurer.xml。正常情况下,在userInfo的定义中不会出现${db.username}、${db.password}等类似信息,这里采用PropertyPlaceholderConfigurer管理username和password属性的取值。DI容器实例化userInfo前,PropertyPlaceholderConfigurer会修改userInfo的元数据信息(<bean/>定义),它会用userinfo.properties中db.username对应的scott值替换${db.username}、db.password对应的tiger值替换${db.password}。最终,DI容器在实例化userInfo时,UserInfo便会得到新的属性值,而不是${db.username}、${db.password}等类似信息。

  1. <bean id="propertyPlaceholderConfigurer"
  2. class="org.springframework.beans.factory.config.
  3. PropertyPlaceholderConfigurer">
  4. <property name="locations">
  5. <list>
  6. <value>userinfo.properties</value>
  7. </list>
  8. </property>
  9. </bean>
  10. <bean name="userInfo" class="test.UserInfo">
  11. <property name="username" value="${db.username}"/>
  12. <property name="password" value="${db.password}"/>
  13. </bean>

通过运行并分析PropertyPlaceholderConfigurerDemo示例应用,开发者能够深入理解PropertyPlaceholderConfigurer。为简化PropertyPlaceholderConfigurer的使用,Spring提供了<context:property-placeholder/>元素。下面给出了配置示例,启用它后,开发者便不用配置PropertyPlaceholderConfigurer对象了。 

<context:property-placeholder location="userinfo.properties"/> 
PropertyPlaceholderConfigurer内置的功能非常丰富,如果它未找到${xxx}中定义的xxx键,它还会去JVM系统属性(System.getProperty())和环境变量(System.getenv())中寻找。通过启用systemPropertiesMode和searchSystemEnvironment属性,开发者能够控制这一行为。

Spring中配置DataSource的六种方式的更多相关文章

  1. Spring中配置DataSource数据源的几种选择

    从JNDI获得DataSource. 从第三方的连接池获得DataSource. 使用DriverManagerDataSource获得DataSource. 一.从JNDI获得DataSource ...

  2. spring配置datasource三种方式

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp34 spring配置datasource三种方式 1.使用org.spri ...

  3. Spring事务配置的五种方式(转发)

    Spring事务配置的五种方式(原博客地址是http://www.blogjava.net/robbie/archive/2009/04/05/264003.html)挺好的,收藏转发 前段时间对Sp ...

  4. Spring事务配置的五种方式和spring里面事务的传播属性和事务隔离级别

    转: http://blog.csdn.net/it_man/article/details/5074371 Spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之 ...

  5. 在Spring中配置SQL server 2000

    前言 Lz主要目的是在Spring中配置SQL server 2000数据库,但实现目的的过程中参差着许多SQL server 2000的知识,也包罗在本文记载下来!(Lz为什么要去搞sql serv ...

  6. spring 中配置sessionFactory及用法

    spring 中配置sessionFactory及用法 方法一: 1.在Spring的applicationContext.xml中配置bean <!-- 启用注解注入  -->      ...

  7. spring中配置数据源

    spring中配置数据源的几种常见方式: #mysql 数据库配置(jdbc.properties) jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.u ...

  8. 在Spring中配置jdbc为什么不能用${username}问题

    楼主在spring中配置jdbc时,引用的是dbcp.jar包,在dataSource.properties配置文件中,有mysql用户名,楼主自然的选择了使用username,密码是root, 然后 ...

  9. spring中配置监听队列的MQ

    一.spring中配置监听队列的MQ相关信息注:${}是读取propertites文件的常量,这里忽略.绿色部分配置在接收和发送端都要配置.  <bean id="axx" ...

随机推荐

  1. __init__特殊方法

    __init__特殊方法不应当返回除了none以外的任何方法.

  2. Http读书笔记1-5章

    第一章 内容提要 这一章主要介绍了什么是http以及http是干嘛的,以及与之有关的相关概念,当然了这些概念都是概览式的介绍一些.所以我将采用问答式的方式描述这一章! Q:http是干嘛的? A:ht ...

  3. 使用Navicat Premium 链接本地数据库的方法(二)

    最早一篇:http://www.cnblogs.com/zhengyeye/p/6363179.html 现在又重新装了电脑系统,需遇到了同样的问题.恰巧记得之前自己写的文档,没准可以帮助自己解决掉这 ...

  4. Python进阶_mysql(1)

    什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据. 进入mysql (linux ...

  5. Java并发编程之Lock

    重入锁ReentrantLock 可以代替synchronized, 但synchronized更灵活. 但是, 必须必须必须要手动释放锁. try { lock.lock(); } finally ...

  6. [LeetCode] Number of Longest Increasing Subsequence 最长递增序列的个数

    Given an unsorted array of integers, find the number of longest increasing subsequence. Example 1: I ...

  7. [SCOI 2010]传送带

    Description 题库链接 在一个 \(2\) 维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段 \(AB\) 和线段 \(CD\) .在 \(AB\) 上的移动速度为 ...

  8. [NOIp 2017]列队

    Description Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有$n \times m$名学生, ...

  9. [BZOJ 3332]旧试题

    Description 圣诞节将至.一年一度的难题又摆在wyx面前——如何给妹纸送礼物. wyx的后宫有n人,这n人之间有着复杂的关系网,相互认识的人有m对.wyx想要量化后宫之间的亲密度,于是准备给 ...

  10. [SCOI2009]围豆豆

    Description Input 第一行两个整数N和M,为矩阵的边长. 第二行一个整数D,为豆子的总个数. 第三行包含D个整数V1到VD,分别为每颗豆子的分值. 接着N行有一个N×M的字符矩阵来描述 ...