hibernate异常:解决Hibernate的Write operations are not allowed in read-only mode (FlushMode.NEVER/MANUAL):

14 篇文章 0 订阅

错误信息:

org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read-only mode (FlushMode.NEVER/MANUAL): Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction definition.

解决方法:

方法1:在出现异常的方法中加入

1 getHibernateTemplate().setFlushMode(HibernateTemplate.FLUSH_EAGER);

方法2:重写OpenSessionInViewFilter 

复制代码
 1 package cn.com.farben.framework.util;
 2  
 3 import org.hibernate.FlushMode;
 4 import org.hibernate.Session;
 5 import org.hibernate.SessionFactory;
 6 import org.springframework.dao.DataAccessResourceFailureException;
 7 import org.springframework.orm.hibernate3.SessionFactoryUtils;
 8  
 9 public class OpenSessionInViewFilter extends
10         org.springframework.orm.hibernate3.support.OpenSessionInViewFilter {
11     protected Session getSession(SessionFactory sessionFactory)
12             throws DataAccessResourceFailureException {
13         Session session = SessionFactoryUtils.getSession(sessionFactory, true);
14         session.setFlushMode(FlushMode.COMMIT);
15         return session;
16     }
17  
18     protected void closeSession(Session session, SessionFactory factory) {
19         session.flush();
20         super.closeSession(session, factory);
21     }
22 }
复制代码

配置web.xml:

复制代码
 1 <filter>
 2     <filter-name>hibernateFilter</filter-name>
 3     <filter-class>cn.com.farben.framework.util.OpenSessionInViewFilter</filter-class>
 4     <init-param>
 5         <param-name>singleSession</param-name>
 6         <param-value>true</param-value>
 7     </init-param>
 8 </filter>
 9 <filter-mapping> 
10     <filter-name>hibernateFilter</filter-name>  
11     <url-pattern>/*</url-pattern> 
12 </filter-mapping>
复制代码

总结:

Write operations are not allowed in read-only mode (FlushMode.NEVER/MANUAL): Turn your Session into FlushMode.COMMIT/AUTO or remove ‘readOnly’ marker from transaction definition.

很明显,从上面的异常信息可以清晰地知道在事务切入的方法中(数据库写入操作)必须将session设置为FlushMode.COMMIT或者FlushMode.AUTO。


转载自:http://blog.csdn.net/yangxiaovip/article/details/45824077

                https://www.cnblogs.com/wahsonleung/p/3505984.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值