abminly 2009-12-07 18:00
浏览 234
已采纳

jdbctemplate是不是应该置为prototype呢?

我觉得应该把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>

  • 写回答

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把当前线程操作的连接储存起来 所以不会出现不安全的问题

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型
  • ¥15 求学软件的前人们指明方向🥺
  • ¥50 如何增强飞上天的树莓派的热点信号强度,以使得笔记本可以在地面实现远程桌面连接
  • ¥20 双层网络上信息-疾病传播