`
seethemoon
  • 浏览: 48365 次
  • 性别: Icon_minigender_1
  • 来自: 钟祥
社区版块
存档分类
最新评论

HibernateDaoSupport getSession()不能释放资源的问题及解决方法

阅读更多
核心提示:1、使用手动释放资源: Sessionsession=getSession(); //代码 //Queryquery=session.createQuery(hql); //query.list(); releaseSession(session); 另外还可以用getHibernateTemplate()来代替。 2、使用注解@Transactional管理事务 这个需要注解驱动: tx:an

1、使用手动释放资源:

  1. Session session = getSession();   
  2.   
  3. //代码   
  4.   
  5. //Query query= session.createQuery(hql);   
  6.   
  7. //query.list();   
  8.   
  9. releaseSession(session);   

另外还可以用getHibernateTemplate()来代替。

2、使用注解@Transactional管理事务

这个需要注解驱动:

  1. <tx:annotation-driven transaction-manager="transactionManager"  
  2.   
  3.                    proxy-target-class="true" />  

在使用类或者方法上用@Transactional注解即可。

3、不使用注解来管理事务,使用声明式事务管理

  1. <tx:advice id="txAdvice" transaction-manager="transactionManager">  
  2.   
  3.           <tx:attributes>  
  4.   
  5.                    <tx:method name="get*" read-only="true" />  
  6.   
  7.                    <tx:method name="*" />  
  8.   
  9.           </tx:attributes>  
  10.   
  11. </tx:advice>  
  12.   
  13.   
  14.   
  15. <aop:config>  
  16.   
  17.           <aop:pointcut id="MyDaoOperation"  
  18.   
  19.                    expression="execution(* x.y.dao.MyDAO.*(..))" />  
  20.   
  21.           <aop:advisor advice-ref="txAdvice" pointcut-ref="MyDaoOperation" />  
  22.   
  23. </aop:config>  

或者

  1. <aop:config>  
  2.   
  3.           <aop:pointcut id="daoOperation"  
  4.   
  5.                    expression="execution(* x.y.dao.*.*(..))" />  
  6.   
  7.           <aop:advisor advice-ref="txAdvice" pointcut-ref="daoOperation" />  
  8.   
  9. </aop:config>  

 

其他事务配置方法参考spring文档或

http://www.blogjava.net/robbie/archive/2009/04/05/264003.html

4、添加openSessionInView,该方法没有亲自测试。

注:1、2、3种方法亲自测试过可以使用,最好的方法是配置spring事务,如果存在

HibernateDaoSupport getSession()连接占用问题,就要检查其spring事务管理的配置是否正确。

参考:http://www.blogjava.net/robbie/archive/2009/04/05/264003.html

 

Spring事务配置的五种方式

    前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识。通过这次的学习发觉Spring的事务配置只要把思路理清,还是比较好掌握的。

    总结如下:

    Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource、TransactionManager和代理机制这三部分,无论哪种配置方式,一般变化的只是代理机制这部分。

    DataSource、TransactionManager这两部分只是会根据数据访问方式有所变化,比如使用Hibernate进行数据访问 时,DataSource实际为SessionFactory,TransactionManager的实现为 HibernateTransactionManager。

    具体如下图:


    根据代理机制的不同,总结了五种Spring事务的配置方式,配置文件如下:

    第一种方式:每个Bean都有一个代理

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:aop="http://www.springframework.org/schema/aop"  
  6.     xsi:schemaLocation="http://www.springframework.org/schema/beans    
  7.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
  8.            http://www.springframework.org/schema/context   
  9.            http://www.springframework.org/schema/context/spring-context-2.5.xsd   
  10.            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">  
  11.   
  12.     <bean id="sessionFactory"     
  13.             class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">     
  14.         <property name="configLocation" value="classpath:hibernate.cfg.xml" />     
  15.         <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration" />  
  16.     </bean>     
  17.   
  18.     <!-- 定义事务管理器(声明式的事务) -->     
  19.     <bean id="transactionManager"  
  20.         class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  21.         <property name="sessionFactory" ref="sessionFactory" />  
  22.     </bean>  
  23.        
  24.     <!-- 配置DAO -->  
  25.     <bean id="userDaoTarget" class="com.bluesky.spring.dao.UserDaoImpl">  
  26.         <property name="sessionFactory" ref="sessionFactory" />  
  27.     </bean>  
  28.        
  29.     <bean id="userDao"     
  30.         class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">     
  31.            <!-- 配置事务管理器 -->     
  32.            <property name="transactionManager" ref="transactionManager" />        
  33.         <property name="target" ref="userDaoTarget" />     
  34.          <property name="proxyInterfaces" value="com.bluesky.spring.dao.GeneratorDao" />  
  35.         <!-- 配置事务属性 -->     
  36.         <property name="transactionAttributes">     
  37.             <props>     
  38.                 <prop key="*">PROPAGATION_REQUIRED</prop>  
  39.             </props>     
  40.         </property>     
  41.     </bean>     
  42. </beans>  

    第二种方式:所有Bean共享一个代理基类

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:aop="http://www.springframework.org/schema/aop"  
  6.     xsi:schemaLocation="http://www.springframework.org/schema/beans    
  7.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
  8.            http://www.springframework.org/schema/context   
  9.            http://www.springframework.org/schema/context/spring-context-2.5.xsd   
  10.            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">  
  11.   
  12.     <bean id="sessionFactory"     
  13.             class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">     
  14.         <property name="configLocation" value="classpath:hibernate.cfg.xml" />     
  15.         <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration" />  
  16.     </bean>     
  17.   
  18.     <!-- 定义事务管理器(声明式的事务) -->     
  19.     <bean id="transactionManager"  
  20.         class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  21.         <property name="sessionFactory" ref="sessionFactory" />  
  22.     </bean>  
  23.        
  24.     <bean id="transactionBase"     
  25.             class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"     
  26.             lazy-init="true" abstract="true">     
  27.         <!-- 配置事务管理器 -->     
  28.         <property name="transactionManager" ref="transactionManager" />     
  29.         <!-- 配置事务属性 -->     
  30.         <property name="transactionAttributes">     
  31.             <props>     
  32.                 <prop key="*">PROPAGATION_REQUIRED</prop>     
  33.             </props>     
  34.         </property>     
  35.     </bean>       
  36.       
  37.     <!-- 配置DAO -->  
  38.     <bean id="userDaoTarget" class="com.bluesky.spring.dao.UserDaoImpl">  
  39.         <property name="sessionFactory" ref="sessionFactory" />  
  40.     </bean>  
  41.        
  42.     <bean id="userDao" parent="transactionBase" >     
  43.         <property name="target" ref="userDaoTarget" />      
  44.     </bean>  
  45. </beans>  
  46.   

第三种方式:使用拦截器

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:aop="http://www.springframework.org/schema/aop"  
  6.     xsi:schemaLocation="http://www.springframework.org/schema/beans    
  7.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
  8.            http://www.springframework.org/schema/context   
  9.            http://www.springframework.org/schema/context/spring-context-2.5.xsd   
  10.            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">  
  11.   
  12.     <bean id="sessionFactory"     
  13.             class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">     
  14.         <property name="configLocation" value="classpath:hibernate.cfg.xml" />     
  15.         <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration" />  
  16.     </bean>     
  17.   
  18.     <!-- 定义事务管理器(声明式的事务) -->     
  19.     <bean id="transactionManager"  
  20.         class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  21.         <property name="sessionFactory" ref="sessionFactory" />  
  22.     </bean>    
  23.       
  24.     <bean id="transactionInterceptor"     
  25.         class="org.springframework.transaction.interceptor.TransactionInterceptor">     
  26.         <property name="transactionManager" ref="transactionManager" />     
  27.         <!-- 配置事务属性 -->     
  28.         <property name="transactionAttributes">     
  29.             <props>     
  30.                 <prop key="*">PROPAGATION_REQUIRED</prop>     
  31.             </props>     
  32.         </property>     
  33.     </bean>  
  34.          
  35.     <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">     
  36.         <property name="beanNames">     
  37.             <list>     
  38.                 <value>*Dao</value>  
  39.             </list>     
  40.         </property>     
  41.         <property name="interceptorNames">     
  42.             <list>     
  43.                 <value>transactionInterceptor</value>     
  44.             </list>     
  45.         </property>     
  46.     </bean>     
  47.      
  48.     <!-- 配置DAO -->  
  49.     <bean id="userDao" class="com.bluesky.spring.dao.UserDaoImpl">  
  50.         <property name="sessionFactory" ref="sessionFactory" />  
  51.     </bean>  
  52. </beans>  
  53.   

第四种方式:使用tx标签配置的拦截器

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:aop="http://www.springframework.org/schema/aop"  
  6.     xmlns:tx="http://www.springframework.org/schema/tx"  
  7.     xsi:schemaLocation="http://www.springframework.org/schema/beans    
  8.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
  9.            http://www.springframework.org/schema/context   
  10.            http://www.springframework.org/schema/context/spring-context-2.5.xsd   
  11.            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd   
  12.            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">  
  13.   
  14.     <context:annotation-config />  
  15.     <context:component-scan base-package="com.bluesky" />  
  16.   
  17.     <bean id="sessionFactory"     
  18.             class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">     
  19.         <property name="configLocation" value="classpath:hibernate.cfg.xml" />     
  20.         <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration" />  
  21.     </bean>     
  22.   
  23.     <!-- 定义事务管理器(声明式的事务) -->     
  24.     <bean id="transactionManager"  
  25.         class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  26.         <property name="sessionFactory" ref="sessionFactory" />  
  27.     </bean>  
  28.   
  29.     <tx:advice id="txAdvice" transaction-manager="transactionManager">  
  30.         <tx:attributes>  
  31.             <tx:method name="*" propagation="REQUIRED" />  
  32.         </tx:attributes>  
  33.     </tx:advice>  
  34.        
  35.     <aop:config>  
  36.         <aop:pointcut id="interceptorPointCuts"  
  37.             expression="execution(* com.bluesky.spring.dao.*.*(..))" />  
  38.         <aop:advisor advice-ref="txAdvice"  
  39.             pointcut-ref="interceptorPointCuts" />           
  40.     </aop:config>         
  41. </beans>  
  42.   

第五种方式:全注解

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:aop="http://www.springframework.org/schema/aop"  
  6.     xmlns:tx="http://www.springframework.org/schema/tx"  
  7.     xsi:schemaLocation="http://www.springframework.org/schema/beans    
  8.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
  9.            http://www.springframework.org/schema/context   
  10.            http://www.springframework.org/schema/context/spring-context-2.5.xsd   
  11.            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd   
  12.            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">  
  13.   
  14.     <context:annotation-config />  
  15.     <context:component-scan base-package="com.bluesky" />  
  16.   
  17.     <tx:annotation-driven transaction-manager="transactionManager"/>  
  18.   
  19.     <bean id="sessionFactory"     
  20.             class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">     
  21.         <property name="configLocation" value="classpath:hibernate.cfg.xml" />     
  22.         <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration" />  
  23.     </bean>     
  24.   
  25.     <!-- 定义事务管理器(声明式的事务) -->     
  26.     <bean id="transactionManager"  
  27.         class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  28.         <property name="sessionFactory" ref="sessionFactory" />  
  29.     </bean>  
  30.        
  31. </beans>  
  32.   

此时在DAO上需加上@Transactional注解,如下:

  1. package com.bluesky.spring.dao;   
  2.   
  3. import java.util.List;   
  4.   
  5. import org.hibernate.SessionFactory;   
  6. import org.springframework.beans.factory.annotation.Autowired;   
  7. import org.springframework.orm.hibernate3.support.HibernateDaoSupport;   
  8. import org.springframework.stereotype.Component;   
  9.   
  10. import com.bluesky.spring.domain.User;   
  11.   
  12. @Transactional  
  13. @Component("userDao")   
  14. public class UserDaoImpl extends HibernateDaoSupport implements UserDao {   
  15.   
  16.     public List<User> listUsers() {   
  17.         return this.getSession().createQuery("from User").list();   
  18.     }   
  19.        
  20.        
  21. }   
  22.   
来源:http://blog.csdn.net/myloon/archive/2009/11/11/4798904.asp
分享到:
评论

相关推荐

    HibernateDaoSupport 与@Autowired

    对于`自定义HibernateDaoSupport`这个文件,可能包含了开发者根据自身需求对`HibernateDaoSupport`的扩展,例如增加特定的查询方法或优化某些操作。这展示了开发者如何在标准库基础上进行定制化开发,以满足项目的...

    hibernateDaoSupport类的运用实例

    这里需要注意的是,`sessionFactory`的配置必须通过`&lt;ref&gt;`元素引用,而不能直接设置。 ##### 2. 获取Session 由于`hibernateDaoSupport`已经提供了获取`Session`的方法,因此我们不再需要手动打开`SessionFactory`...

    HibernateDaoSupport的使用

    这个类的主要作用是为实现DAO层的类提供对Hibernate SessionFactory和Session的访问,从而简化了DAO的实现,使得开发者无需直接管理Session的生命周期,避免了常见的资源泄露问题。 二、`HibernateDaoSupport`的...

    HibernateDaoSupport二次封装组件,快速统计和查询,修改

    通过`getSession().createQuery()`或`getSession().createCriteria()`创建查询,设置参数,添加分页限制,最后执行`list()`获取结果集。 3. **修改操作**:对于更新,我们可以创建一个`updateByQuery`方法,接收HQL...

    spring 理解文件HibernateDaoSupport

    根据给定的信息,我们可以深入探讨Spring框架中与Hibernate集成的相关知识点,特别关注“HibernateDaoSupport”类及其在Spring环境中的应用。以下是对标题、描述以及部分文件内容的详细解析: ### 一、Spring与...

    HibernateDaoSupport 源码

    Spring hibernate3. HibernateDaoSupport 源码

    HibernateDaoSupport 类的jar

    HibernateDaoSupport 类的jar HibernateDao 的jar

    SSH整合(其中dao用extends HibernateDaoSupport方式)总结【图解】

    SSH整合(其中dao用extends HibernateDaoSupport方式)总结【图解】

    HibernateDaoSupport分页.

    通过以上分析可以看出,利用`HibernateDaoSupport`实现分页查询不仅能够有效地提高代码的可维护性和可读性,还能确保数据库查询的高效执行。开发者可以根据实际需求灵活选择不同的分页方法来满足项目的需求。此外,...

    springboot2.0多数据源集成hibernate配置hibernateDaoSupport示例

    在DAO层,我们不使用JPA,而是使用`HibernateDaoSupport`。`HibernateDaoSupport`是Spring提供的一类辅助类,它提供了与Hibernate SessionFactory的连接,简化了Hibernate的使用。首先,我们需要创建一个基础的DAO...

    hibernateDaoSupport.txt

    综上所述,在开发DAO层时,通过引入抽象层并合理利用`HibernateDaoSupport`等工具类,不仅可以降低代码与框架之间的耦合度,提高代码的可维护性和灵活性,还能有效应对未来可能的技术变迁带来的挑战。这种设计思想...

    HibernateDaoSupport.docx

    【HibernateDaoSupport】是Spring框架中的一个抽象类,主要用于简化Hibernate的数据访问操作,它为DAO层提供了方便的事务管理和Session管理。这个类是Spring与Hibernate集成的重要组件,尤其对于初学者来说,理解其...

    hibernateTemplate和HibernateDaoSupport

    hibernateTemplate 和 HibernateDaoSupport 是 Spring 框架中针对 Hibernate 数据库访问层的两个重要组件,它们简化了基于 Hibernate 的数据操作,使得开发者能够更高效地进行 CRUD(创建、读取、更新、删除)操作。...

    HibernateDaoSupport与JdbcDaoSupport

    ### HibernateDaoSupport与JdbcDaoSupport详解 #### 一、概述 在软件开发过程中,特别是企业级应用开发中,数据库操作是一项重要的任务。为了简化这一过程并提高代码的可维护性和扩展性,Spring框架提供了多种支持...

    HibernateTemplate及generator用法.docx

    原因是`getSession()`会在每个操作时创建新的Session,如果在一个线程中有大量的并发操作,这可能导致数据库连接数过多,超出数据库允许的最大连接数,从而引发性能问题。而`getHibernateTemplate()`则能更好地管理...

    HibernateTemplate及generator用法.doc

    而`HibernateTemplate`则可以更好地控制和管理Session,避免这个问题。 以下是`getSession`的一些常用操作: - 查询:`getSession().find()`, `getSession().createQuery()` - 保存:`getSession().save()`, `...

    JSP 开发之 releaseSession的实例详解

    然而,仅仅在每次查询后调用`getSession().close()`来关闭Session并不足够,因为这样并不能确保在多线程环境下正确地释放Session资源。 `releaseSession(Session session)`方法的引入是为了解决这个问题。这个方法...

    JPA(hibernate) Dao 和 DaoSupport

    继承自`DaoSupport`的DAO类可以利用其提供的便利方法,如`getJdbcTemplate()`或`getHibernateTemplate()`,来简化数据库操作。不过,现在更推荐使用Spring Data JPA,它提供了更高级别的抽象,减少了手动编写DAO层...

    jsp中调用dao的getHibernateTemplate()时,报空指针

    本文将讲解这个问题的原因和解决方法。 在 SSH 框架中,DAO(Data Access Object)是负责与数据库交互的对象,而 HibernateTemplate 则是 Hibernate 框架提供的一个模板类,用于简化数据库操作。通常情况下,我们在...

    Spring+Hibernate实现增删改查的两种方法

    HibernateDaoSupport是Spring提供的抽象类,提供了对SessionFactory的便捷访问,但不提供预定义的操作。使用HibernateDaoSupport时,你需要自己编写HQL或Criteria查询。 1. **配置HibernateDaoSupport** 类似于...

Global site tag (gtag.js) - Google Analytics