org.springframework.jdbc.datasource.DriverManagerDataSource
说明:DriverManagerDataSource
创建链接是只要有链接就新建一个connection,根本没有链接池的做用。java
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName"><value>${jdbc.driverClassName}</value></property> <property name="url"><value>${jdbc.url}</value></property> <property name="username"><value>${jdbc.username}</value></property> <property name="password"><value>${jdbc.password}</value></property> </bean>
说明:这是一种推荐说明的数据源配置方式,它真正使用了链接池技术mysql
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName"> <value>Oracle.jdbc.driver.OracleDriver</value> </property> <property name="url"> <value>jdbc:oracle:thin:@localhost:1521:orcl</value> </property> <property name="username"> <value>test</value> </property> <property name="password"> <value>test</value> </property> <property name="maxActive"> <value>255</value> </property> <property name="maxIdle"> <value>2</value> </property> <property name="maxWait"> <value>120000</value> </property> </bean>
说明:JndiObjectFactoryBean 可以经过JNDI获取DataSourceweb
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName"> <value>Java:comp/env/jdbc/roseindiaDB_local</value> </property> </bean>
*总结:3种方式中的第一种没有使用链接池,故少在项目中用到,第三种方式须要在web server中配置数据源,不方便于部署,本人推荐使用每二种方式进行数据源的配置。 *spring
spring在第三方依赖包中包含了两个数据源的实现类包,其一是Apache的DBCP,其二是 C3P0。能够在Spring配置文件中利用这二者中任何一个配置数据源。sql
DBCP是一个依赖 Jakarta commons-pool对象池机制的数据库链接池数据库
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3309/sampledb" /> <property name="username" value="root" /> <property name="password" value="1234" /> </bean>
BasicDataSource
提供了close()
方法关闭数据源,因此必须设定destroy-method="close"
属性, 以便Spring容器关闭时,数据源可以正常关闭。除以上必须的数据源属性外,还有一些经常使用的属性:apache
C3P0是一个开放源代码的JDBC数据源实现项目,它在lib目录中与hibernate一块儿发布,实现了JDBC3和JDBC2扩展规范说明的 Connection 和Statement 池。缓存
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass" value=" oracle.jdbc.driver.OracleDriver "/> <property name="jdbcUrl" value=" jdbc:oracle:thin:@localhost:1521:ora9i "/> <property name="user" value="admin"/> <property name="password" value="1234"/> </bean>
ComboPooledDataSource
和BasicDataSource
同样提供了一个用于关闭数据源的close()
方法,这样咱们就能够保证Spring容器关闭时数据源可以成功释放。服务器
C3P0拥有比DBCP更丰富的配置属性,经过这些属性,能够对数据源进行各类有效的控制:多线程
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location" value="/WEB-INF/jdbc.properties"/> </bean> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driverClassName}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </bean>
在jdbc.properties属性文件中定义属性值:
jdbc.driverClassName= com.mysql.jdbc.Driver jdbc.url= jdbc:mysql://localhost:3309/sampledb jdbc.username=root jdbc.password=1234
提示 常常有开发者在${xxx}的先后不当心键入一些空格,这些空格字符将和变量合并后做为属性的值。如: <property name="username" value=" ${jdbc.username} "></property>
的属性配置项,在先后都有空格,被解析后,username的值为“ 1234 ”
,这将形成最终的错误,所以须要特别当心。
若是应用配置在高性能的应用服务器(如WebLogic或Websphere等)上,咱们可能更但愿使用应用服务器自己提供的数据源。应用服务器的数据源 使用JNDI开放调用者使用,Spring为此专门提供引用JNDI资源的JndiObjectFactoryBean类。下面是一个简单的配置:
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName" value="java:comp/env/jdbc/bbt"/> </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>
Spring自己也提供了一个简单的数据源实现类DriverManagerDataSource ,它位于org.springframework.jdbc.datasource包中。这个类实现了javax.sql.DataSource接口,但 它并无提供池化链接的机制,每次调用getConnection()获取新链接时,只是简单地建立一个新的链接。所以,这个数据源类比较适合在单元测试 或简单的独立应用中使用,由于它不须要额外的依赖类。
下面,咱们来看一下DriverManagerDataSource的简单使用:固然,咱们也能够经过配置的方式直接使用DriverManagerDataSource。
DriverManagerDataSource ds = new DriverManagerDataSource (); ds.setDriverClassName("com.mysql.jdbc.Driver"); ds.setUrl("jdbc:mysql://localhost:3309/sampledb"); ds.setUsername("root"); ds.setPassword("1234"); Connection actualCon = ds.getConnection();
无论采用何种持久化技术,都须要定义数据源。Spring附带了两个数据源的实现类包,你能够自行选择进行定义。在实际部署时,咱们可能会直接采用应用服 务器自己提供的数据源,这时,则能够经过JndiObjectFactoryBean或jee命名空间引用JNDI中的数据源。
C3PO :DBCP:
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass"> <value>oracle.jdbc.driver.OracleDriver</value> </property> <property name="jdbcUrl"> <value>jdbc:oracle:thin:@10.10.10.6:1521:DataBaseName</value> </property> <property name="user"> <value>testAdmin</value> </property> <property name="password"> <value>123456</value> </property> /bean>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName"> <value>oracle.jdbc.driver.OracleDriver</value> </property> <property name="url"> <value>jdbc:oracle:thin:@10.10.10.6:1521:DataBaseName</value> </property> <property name="username"> <value>testAdmin</value> </property> <property name="password"> <value>123456</value> </property> </bean>