使用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>