您的位置:首页 > 数据库

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

2012-06-26 00:10 537 查看
使用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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  session filter 数据库
相关文章推荐