您的位置:首页 > 其它

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

2016-12-27 00:45 483 查看
可以在spring配置文件中把事务详情标签里加上,所出错的方法,然后完美解决

<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<tx:method name="add*"/>
<tx:method name="delete*"/>
<tx:method name="update*"/>
<tx:method name="saveOrUpdate"/>
<tx:method name="find*" read-only="true"/>
<tx:method name="login" read-only="true"/>
</tx:attributes>
</tx:advice>

以下是其他网友的解决方法:

使用openSessionViewFilter经常出现的一个错是【Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction definition.】

原因大致是:这个拦截器会延迟session的关闭,当你在请求后如果执行一个查询语句然后再执行修改语句这样就会出现这个错误,因为在执行查询的时候openSessionViewFilter会把你查询设置为只读模式FlushMode.NEVER(这是它的默认,表示不会把你的数据与数据库进行同步),这是解决方法

(1)有配置事务;

(2)web.xml配置里添加

<filter>

   <filter-name>OpenSessionInViewFilter</filter-name>

   <filter-class>

    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter

   </filter-class>

   <init-param>

    <param-name>sessionFactoryBeanName</param-name>

    <param-value>sessionFactory</param-value>

   </init-param>

   <init-param>

            <param-name>singleSession</param-name>

            <param-value>true</param-value>           

        </init-param>

        <init-param>

        <param-name> flushMode </param-name>

   <param-value>AUTO </param-value>        

        </init-param>

</filter>

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐