Spring 框架获取 datasource对象的方法

1,使用org.springframework.jdbc.datasource.DriverManagerDataSource 

2.使用org.apache.commons.dbcp.BasicDataSource 

3.使用org.springframework.jndi.JndiObjectFactoryBean 
总结:3种方式中的第一种没有使用连接池,故少在项目中用到,第三种方式需要在web server中配置数据源,不方便于部署,本人推荐使用每二种方式进行数据源的配置。

 

读配置文件的方式引用属性:

<bean id="propertyConfigurer"   
2.class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">   
3.    <property name="location" value="/WEB-INF/jdbc.properties"/>   
4.</bean>   

 

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"   
2.destroy-method="close">   
3.    <property name="driverClassName" value="${jdbc.driverClassName}" />   
4.    <property name="url" value="${jdbc.url}" />   
5.    <property name="username" value="${jdbc.username}" />   
6.    <property name="password" value="${jdbc.password}" />   
7.</bean>  

 

在jdbc.properties属性文件中定义属性值: 
    jdbc.url= jdbc:mysql://localhost:3309/sampledb jdbc.username=root jdbc.password=1234 

提示 经常有开发者在${xxx}的前后不小心键入一些空格,这些空格字符将和变量合并后作为属性的值。如: <property name="username" value=" ${jdbc.username} "></property> 的属性配置项,在前后都有空格,被解析后,username的值为“ 1234 ”,这将造成最终的错误,因此需要特别小心。

 

获取JNDI数据源 

如果应用配置在高性能的应用服务器(如WebLogic或Websphere等)上,我们可能更希望使用应用服务器本身提供的数据源。应用服务器的数据源 使用JNDI开放调用者使用,Spring为此专门提供引用JNDI资源的JndiObjectFactoryBean类。下面是一个简单的配置:

<bean id="dataSource"  class="org.springframework.jndi.JndiObjectFactoryBean">   
    <property name="jndiName" value="java:comp/env/jdbc/bbt"/>        
</bean>    

  <bean id="performanceDataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
  <property name="jndiName" value="${performance.jdbc.jndi.name}" />
 </bean>

Spring 2.0为获取J2EE资源提供了一个jee命名空间,通过jee命名空间,可以有效地简化J2EE资源的引用。下面是使用jee命名空间引用JNDI数据源的配置:

<beans xmlns=http://www.springframework.org/schema/beans      
xmlns:xsi=http://www.w3.org/2001/XMLSchema-instance      
xmlns:jee=http://www.springframework.org/schema/jee      
xsi:schemaLocation="http://www.springframework.org/schema/beans       
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd       
http://www.springframework.org/schema/jee      
http://www.springframework.org/schema/jee/spring-jee-2.0.xsd">        
    <jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/jdbc/bbt"/>        
</beans>    

 

你可能感兴趣的:(dataSource)