使用proxool连接池 ,连接没有关闭的原因

遇到的问题: 

    使用如下方法查询,连接不能正常关闭: 

        方式1:   SQLQuery query=getSession().createSQLQuery(sql.toString());

           如果事务配置正确的话,方式1可以.

        方式2:  Session session = this.getHibernateTemplate().getSessionFactory().openSession();
             List<Object[]> cList= session.createSQLQuery(sql).list();

           该方式不受spring事务管理,需要修改为如下方式:

                Session session = this.getSession();
Query query = session.createSQLQuery(sql);
List<Object[]> cList= query.list();

          这样修改后,如果事务配置正确,则session能正常关闭.


      如果事务配置不正确, 为了以防万一,可以在代码中添加如下代码,关闭session:    releaseSession(session);//  这是spring自己提供的方法


    正确的事务配置如下:

   <bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation" value="classpath:hibernate.cfg.xml">
</property>
</bean>

<!-- 配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<!-- 哪些类哪些方法使用事务 -->
<aop:config>
<aop:pointcut id="allServiceMethod"
expression="execution(* com.bbc.*.*.service.impl.*.*(..))" />
<aop:advisor advice-ref="txAdvice" pointcut-ref="allServiceMethod" />
</aop:config>
<!-- 事务的传播特性 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="save*" propagation="REQUIRED" />
<tx:method name="*" propagation="REQUIRED" />
</tx:attributes>
</tx:advice>


 当时由于事务配置中的包路径写错了,导致session关闭没有通过spring事务控制,造成session一直未关闭. 结果强制使用 releaseSession(session); 也到实现了session关闭.其实当事务配置正确后,就不需要 releaseSession(session);  了.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值