zoukankan      html  css  js  c++  java
  • 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>    
    
  • 相关阅读:
    操作系统-进程(1)进程与进程调度
    算法-图(6)广度优先遍历图
    网络摄像头RTSP流媒体协议视频平台EasyNVR如何进行延迟测试?
    【方案搭建】如何通过RTSP协议视频平台EasyNVR架设智慧城市实景终端展现方案?
    【解决方案】如何通过RTSP流媒体协议视频平台EasyNVR搭建智慧景区远程视频监管平台?
    7-12 排序 (25分)
    7-36 社交网络图中结点的“重要性”计算 (30分)-floyd最短路径
    7-35 城市间紧急救援 (25分)-dijkstra最短路径
    7-34 任务调度的合理性 (25分)--拓扑排序
    7-33 地下迷宫探索 (30分)--DFS
  • 原文地址:https://www.cnblogs.com/wupeng88/p/4601814.html
Copyright © 2011-2022 走看看