view plain
copy to clipboard
print
?
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jee="http://www.springframework.org/schema/jee" xsi:schemaLocation="http: http: http: http: http: http: http: <context:property-placeholder location="classpath:jdbc_config.properties"/> <!-- DriverManagerDataSource:在每个连接请求时新建一个连接。 SingleConnectionDataSource:在每个连接请求时都返回同一连接。 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="${driverClassName}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </bean> </beans>
。。。。。
view plain
copy to clipboard
print
?
<context:property-placeholder location="classpath:dbcp_config.properties" /> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driverClassName}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="initialSize" value="${initialSize}"/> <property name="maxActive" value="${maxActive}"/> <property name="maxIdle" value="${maxIdle}"/> <property name="minIdle" value="${minIdle}"/> <property name="maxWait" value="${maxWait}"/> <property name="defaultAutoCommit" value="${defaultAutoCommit}"/> </bean>
。。。。。
view plain
copy to clipboard
print
?
<context:property-placeholder location="classpath:c3p0_config.properties"/> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="user" value="${user}"/> <property name="password" value="${password}"/> <property name="jdbcUrl" value="${jdbcUrl}"/> <property name="driverClass" value="${driverClass}"/> <property name="checkoutTimeout" value="${checkoutTimeout}"/> <property name="idleConnectionTestPeriod" value="${idleConnectionTestPeriod}"/> <property name="initialPoolSize" value="${initialPoolSize}"/> <property name="maxIdleTime" value="${maxIdleTime}"/> <property name="maxPoolSize" value="${maxPoolSize}"/> <property name="minPoolSize" value="${minPoolSize}"/> <property name="maxStatements" value="${maxStatements}"/> </bean>
。。。。。
view plain
copy to clipboard
print
?
<!-- <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean" scope="singleton"> <property name="jndiName" value="/jdbc/spring-jndi" /> < !-- 当resourceRef 属性为true时,jndiName会被添加java:comp/env/,从应用服务器的JNDI目录获取数据源 -- > <property name="resourceRef" ref="true" /> </bean> --> <!-- jee 命名空间里的jee:jndi-lookup 元素可以从jndi获取对象。下面的XML等效于前面对JndiObjectFactoryBean的明确声明 --> <jee:jndi-lookup id="dataSource" jndi-name="/jdbc/spring-jndi" resource-ref="true"/>
。。。。。
测试使用一下
view plain
copy to clipboard
print
?
<import resource="classpath:bean-dbcp.xml" /> <bean id="helloJdbcDao" class="cn.partner4java.jdbc.impl.HelloJdbcDaoBean"> <property name="dataSource" ref="dataSource"/> </bean>
。。。。。。
view plain
copy to clipboard
print
?
package cn.partner4java.jdbc; import java.sql.Connection; import java.sql.SQLException; public interface HelloJdbcDao { public Connection getConnection() throws SQLException; }
。。。。。。
view plain
copy to clipboard
print
?
package cn.partner4java.jdbc.impl; import java.sql.Connection; import java.sql.SQLException; import javax.sql.DataSource; import cn.partner4java.jdbc.HelloJdbcDao; public class HelloJdbcDaoBean implements HelloJdbcDao{ public DataSource dataSource; public void setDataSource(DataSource dataSource) { this.dataSource = dataSource; } public Connection getConnection() throws SQLException { return dataSource.getConnection(); } }
。。。。。
view plain
copy to clipboard
print
?
package cn.partner4java.jdbc.junit; import java.sql.SQLException; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import cn.partner4java.jdbc.HelloJdbcDao; import junit.framework.TestCase; public class HelloJdbcDaoBeanTest extends TestCase { public HelloJdbcDao helloJdbcDao; @Override protected void setUp() throws Exception { ApplicationContext ac = new ClassPathXmlApplicationContext("beans-jdbc.xml"); helloJdbcDao = (HelloJdbcDao) ac.getBean("helloJdbcDao"); } public void testGetConn() throws SQLException{ System.out.println(helloJdbcDao.getConnection()); } }