• Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction 异常一例


    参考下面的文章,最终找到我的报错原因:

    我是在 service中一个以 get开头的方法中,加入了一行数据库数据删除代码,因为

    spring的事务配置中,配置了get开头的方法 是 readonle的:

      <tx:method name="get*" propagation="REQUIRED" read-only="true" />  

                <tx:method name="count*" propagation="REQUIRED" read-only="true" />  

                <tx:method name="find*" propagation="REQUIRED" read-only="true" />  

                <tx:method name="list*" propagation="REQUIRED" read-only="true" />  

                <tx:method name="*" read-only="true" /> 

    所以导致了这个异常。

    解决方法很简单,把这个方法重新起了个不是 以 get 开头的名字就解决了。

    下面的文章仅供参考:

    转:

    [SSH] Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/mjl960108/article/details/53610578

    当执行到service层时,发生了如题的错误。
    原因:

    OpenSessionInViewFilter在getSession的时候,会把获取回来的session的flush mode
    设为FlushMode.NEVER。然后把该sessionFactory绑定到TransactionSynchronizationManager,使request的整个过程都使用同一个session,在请求过后再接除该sessionFactory的绑定,最后closeSessionIfNecessary根据该session是否已和transaction绑定来决定是否关闭session。在这个过程中,若HibernateTemplate
    发现自当前session有不是readOnly的transaction,就会获取到FlushMode.AUTO
    Session,使方法拥有写权限。也即是,如果有不是readOnly的transaction就可以由Flush.NEVER转为Flush.AUTO,拥有insert,update,delete操作权限,如果没有transaction,并且没有另外人为地设flush
    model的话,则doFilter的整个过程都是Flush.NEVER。所以受transaction(声明式的事务)保护的方法有写权限,没受保护的则没有。

    解决办法:在spring配置文件中加上这一部分

    <tx:advice id="txAdvice" transaction-manager="transactionManager">
            <tx:attributes>
                    <tx:method name="create*" propagation="REQUIRED" />
                    <tx:method name="save*" propagation="REQUIRED" />
                    <tx:method name="add*" propagation="REQUIRED" />
                    <tx:method name="update*" propagation="REQUIRED" />
                    <tx:method name="remove*" propagation="REQUIRED" />
                    <tx:method name="del*" propagation="REQUIRED" />
                    <tx:method name="import*" propagation="REQUIRED" />
                    <tx:method name="*" propagation="REQUIRED"/>
                    <!--这里如果觉着麻烦只要最后一行*就可以了,因为他会扫描所有的函数的 -->
                </tx:attributes>
            </tx:advice>
    
            <aop:config proxy-target-class="true">
                <aop:pointcut id="serviceOperation" expression="execution(* com.hdu.service.impl..*(..))" />
                <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceOperation" />

    或者如果不想配置配置文件

    ,请在service层上面加上一个@Transactional

    这样service层就加入了事务列,然后在所有的dao层中的操作加一行getSessionFactory().getCurrentSession().setFlushMode(FlushMode.AUTO);像下面这样

    public void doCreateUser(Student student) {
        getSessionFactory().getCurrentSession().setFlushMode(FlushMode.AUTO);
            this.getHibernateTemplate().save(student);         
    
        }
  • 相关阅读:
    Hibernate中的HQL
    hibernate配置数据库连接池三种用法
    Hibernate的延迟检索和立即检索
    Hibernate关系映射中的注解
    Hibernate的多种关系映射(oto、otm、mtm)
    自然主键和代理主键的区别
    Hibernate的xml方法配置和操作代码
    Hibernate简介
    VirtualBox从USB设备(PE)启动图文教程
    属性动画
  • 原文地址:https://www.cnblogs.com/libin6505/p/10422132.html
Copyright © 2020-2023  润新知