我觉得应该把jdbctemplate设为多例的,因为dataSource是线程安全的(同步的).
在项目只有一个数据源(dataSource),可以有多个连接(jdbctemplate).
这样才能保证数据的安全性.
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<!-- bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean-->
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:/datasource/jdbc.properties</value>
</list>
</property>
</bean>
<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}"/>
</bean>
<bean id="jdbctemplate" class="org.springframework.jdbc.core.JdbcTemplate" scope="prototype">
<constructor-arg ref="dataSource"/>
</bean>
<bean id="abstractSupperDao" class="com.huawei.bus.dao.AbstractSupperDao" scope="singleton">
<property name="jdbctemplate" ref="jdbctemplate"/>
</bean>
</beans>
jdbctemplate是不是应该置为prototype呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- wocsok 2009-12-07 22:17关注
其实不用,多此一举了。。。呵呵
jdbcTemplate早就给你做了
他是一种模板方法 在里面开启关闭连接的
取得连接里面有段
(ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);
它已经给你做了同步的处理 然后有个这段代码
if (TransactionSynchronizationManager.isSynchronizationActive()) {
logger.debug("Registering transaction synchronization for CCI Connection");
conHolder = new ConnectionHolder(con);
conHolder.setSynchronizedWithTransaction(true);
TransactionSynchronizationManager.registerSynchronization(new ConnectionSynchronization(conHolder, cf));
TransactionSynchronizationManager.bindResource(cf, conHolder);
}
它是在里面通过ThreadLocal把当前线程操作的连接储存起来 所以不会出现不安全的问题本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报