我遇到了Hibernate的行为,我不知道它是否是我的代码中的一个功能或错误/错误使用hibernate。
我的会话的FlushMode设置为FlushMode.AUTO
。如果我执行一个select查询,那么hibernate autoflush过程会跳入并尝试更新一个实体,因为它认为它是脏的。但是,我没有在我的会话中的某个地方调用此实体的update(),我甚至认为我没有修改它,甚至不是因为级联。
结果是自动更新的脏实体导致我的数据库处于不需要的状态。我正在使用SaveUpdate实体侦听器跟踪实体的这种不需要的更新。
我正在从堆栈跟踪中收集所有这些信息(我向您展示了一段摘录,我上面提到的理论可能是错误的;)
2011-06-24 09:51:07,790 28671957 (SaveUpdateEventListener.java:140) FATAL - Stacktrace from last unwanted update
java.lang.Exception
at a.b.dao.listener.SaveUpdateEventListener.checkEntity(SaveUpdateEventListener.java:138)
at a.b.dao.listener.SaveUpdateEventListener.onSaveOrUpdate(SaveUpdateEventListener.java:38)
at org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl.java:535)
at org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java:527)
at org.hibernate.engine.CascadingAction$5.cascade(CascadingAction.java:241)
at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:292)
at org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java:240)
at org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:193)
at org.hibernate.engine.Cascade.cascade(Cascade.java:154)
at org.hibernate.event.def.AbstractFlushingEventListener.cascadeOnFlush(AbstractFlushingEventListener.java:154)
at org.hibernate.event.def.AbstractFlushingEventListener.prepareEntityFlushes(AbstractFlushingEventListener.java:145)
at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:88)
at org.hibernate.event.def.DefaultAutoFlushEventListener.onAutoFlush(DefaultAutoFlushEventListener.java:58)
at org.hibernate.impl.SessionImpl.autoFlushIfRequired(SessionImpl.java:997)
at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1142)
at org.hibernate.impl.QueryImpl.list(QueryImpl.java:102)
at org.springframework.orm.hibernate3.HibernateTemplate$30.doInHibernate(HibernateTemplate.java:921)
at org.springframework.orm.hibernate3.HibernateTemplate$30.doInHibernate(HibernateTemplate.java:1)
at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:406)
at org.springframework.orm.hibernate3.HibernateTemplate.executeWithNativeSession(HibernateTemplate.java:374)
at org.springframework.orm.hibernate3.HibernateTemplate.find(HibernateTemplate.java:912)
>> at a.b.dao.pricing.PricingDao.list(PricingDao.java:36) << THE SELECT STATEMENT
at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:191)
at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:688)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:621)
...
那么,脏字段的自动更新是一项功能吗?如果是,是由FlushMode.AUTO引起的,我是否可以使用FlushMode.MANUAL禁用此功能?
答案 0 :(得分:4)
你必须对有问题的对象做一些让Hibernate认为它们变脏的东西。不要试图破坏正常的Hibernate行为,而是尝试在代码中找到Hibernate的错误/错误。
或者,如果你绝对不需要Hibernate会话的智能来检测脏对象并根据它发出插入,更新和删除,请考虑使用Hibernate无状态会话。