zoukankan      html  css  js  c++  java
  • org.hibernate.HibernateException: No Session found for current thread

    spring、springmvc和hibernate整合

    在sessionFactory.getCurrentSession()时,出现以下异常
    No Session found for current thread

    但使用sessionFactory.openSession()是没有任何问题的
    严重: Servlet.service() for servlet [springDispatcherServlet] in context with path [/Demo] threw exception [Request processing failed; nested exception is org.hibernate.HibernateException: No Session found for current thread] with root cause
    org.hibernate.HibernateException: No Session found for current thread
        at org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:106)
        at org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:988)
        at com.wzy.dao.BookShopDaoImpl.getAll(BookShopDaoImpl.java:16)
        at com.wzy.services.impl.BookSerImpl.getALL(BookSerImpl.java:19)
        at com.wzy.controller.Test.hello(Test.java:36)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
        at java.lang.reflect.Method.invoke(Unknown Source)
    1. getCurrentSession和openSession之间有什么不同呢

    getCurrentSession的话会自动关闭,而openSession需要你手动关闭。
    如果你正在查询,使用的openSession而没有手动关闭,多次之后会导致连接池溢出。
    getCurrentSession是与当前线程绑定的,当前线程结束时,session也会自动关闭
    getCurrentSession是比较安全的,建议使用
    2. 获取getCurrentSession时,为什么会出现以上异常
    是因为没有配置事务
    spring hibernate事务的流程
    在方法开始之前,获取session,把session和当前线程绑定,这样就可以在dao中使用sessionFactory.getCurrentSession()来获取session了,然后开启事务。

    若方法正常结束,即没有异常,则提交事务,解除和当前线程绑定的session,关闭session。

    若方法出现异常,则回滚事务,解除绑定,关闭session。



    3. 怎么配置事务
    如下是spring的配置文件
    <?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:tx="http://www.springframework.org/schema/tx"
        xmlns:aop="http://www.springframework.org/schema/aop"
        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd">
          
        
         <context:component-scan base-package="com.wzy">
         <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
         </context:component-scan>
        <context:property-placeholder location="classpath:db.properties"/>
        <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <property name="user" value="${jdbc.user}"></property>
            <property name="password" value="${jdbc.password}"></property>
            <property name="driverClass" value="${jdbc.driverClass}"></property>
            <property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
            <property name="initialPoolSize" value="${jdbc.initPoolSize}"></property>
            <property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
            
        </bean>
        <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
            <property name="dataSource" ref="dataSource"></property>
            <property name="mappingLocations" value="classpath:com/wzy/entities/*.hbm.xml"></property>
            <!--
            <property name="configLocation" value="classpath:hibernate.cfg.xml"></property>
            -->
            <property name="hibernateProperties">
               <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                   </props>
            </property>
        </bean>
        
        
        <!-- 配置 Spring 的声明式事务 
         1. 配置 hibernate 的事务管理器 -->
        <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
            <property name="sessionFactory" ref="sessionFactory"></property>
        </bean>
    
        <!--  2. 配置事务属性 --> 
        <tx:advice id="txAdvice" transaction-manager="transactionManager">
            <tx:attributes>
                <tx:method name="get*" read-only="true"/>
                <tx:method name="*"/>
            </tx:attributes>
        </tx:advice>
        
         <!--  3. 配置事务切入点, 再把事务属性和事务切入点关联起来
         
        <aop:config>
            <aop:pointcut expression="execution(* com.wzy.services.*.*(..))" id="txPointcut"/>
            <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
        </aop:config>
        --> 
        
    </beans>

     4. 为什么我spring的配置文件已经配置好了,还是会出那个异常呢

    如果是spring、strut2、hibernate整合的话,事务在spring的配置文件中配置就行

    但如果是spring、springmvc、hibernate整合的话,事务切入点得配置在springmvc的配置文件中

    因为spring和springmvc是两个容器

    只需要把spring配置文件中的<!-- 3. 配置事务切入点, 再把事务属性和事务切入点关联起来-->

    放到springmvc的配置文件中就可以了,spring中的那块就可以去掉了

    如下是springMVC的配置文件

    <?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:mvc="http://www.springframework.org/schema/mvc"
        xmlns:aop="http://www.springframework.org/schema/aop"
        xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
            http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">
         
          <context:component-scan base-package="com.wzy"></context:component-scan>
        
         <!--  3. 配置事务切入点, 再把事务属性和事务切入点关联起来-->
        <aop:config>
            <aop:pointcut expression="execution(* com.wzy.services.*.*(..))" id="txPointcut"/>
            <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
        </aop:config>
    </beans>
    总的来说,当spring、springmvc和hibernate整合时
    在sessionFactory.getCurrentSession()时,出现No Session found for current thread
    需要配置事务,并且在springmvc配置文件中配置事务的切入点







  • 相关阅读:
    使用NDK开发SQLite3
    SQL Server 2005 Default Trace (默认跟踪)
    MySQL 获得当前日期时间 函数
    利用UltraISO写入U盘安装系统,条件:电脑支持USBHDD ,U盘容量足够
    Sicily 1157 The hardest problem
    Histogram of oriented gradients(HOG)
    IE中的CSS3不完全兼容方案
    MySQL如何查询两个日期之间的记录
    查找某个字段最大值的记录 SQL 语句
    用 jQuery 实现页面滚动(Scroll)效果的完美方法
  • 原文地址:https://www.cnblogs.com/wwzyy/p/5560935.html
Copyright © 2011-2022 走看看