来自grails项目的hibernate AssertionFailure

时间:2010-12-06 15:06:29

标签: sql hibernate grails groovy

我收到的错误如下所示。这与我的级联设置方式有关吗?开始调查的适当场所在哪里?现在我有一个角色,有很多角色责任。 RoleDuty属于角色。 RoleDuty只有一个字段,duty,这是一个可以为空的字符串。 Role具有RoleDuties列表的all-delete-orphan映射。

06.12.2010 10:02:17 *ERROR* AssertionFailure: an assertion failure occured (this may indicate a bug in Hibernate, but is
 more likely due to unsafe use of the session) (AssertionFailure.java, line 47)
org.hibernate.AssertionFailure: null id in RoleDuty entry (don't flush the Session after an exception occurs)
        at org.hibernate.event.def.DefaultFlushEntityEventListener.checkId(DefaultFlushEntityEventListener.java:78)
        at org.hibernate.event.def.DefaultFlushEntityEventListener.getValues(DefaultFlushEntityEventListener.java:187)
        at org.hibernate.event.def.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:14
3)
        at org.hibernate.event.def.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:219)
        at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListen
er.java:99)
        at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:49)
        at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1027)
        at org.springframework.orm.hibernate3.HibernateAccessor.flushIfNecessary(HibernateAccessor.java:390)
        at org.codehaus.groovy.grails.orm.hibernate.support.GrailsOpenSessionInViewInterceptor.flushIfNecessary(GrailsOp
enSessionInViewInterceptor.java:116)
        at org.springframework.orm.hibernate3.support.OpenSessionInViewInterceptor.postHandle(OpenSessionInViewIntercept
or.java:181)
        at org.codehaus.groovy.grails.orm.hibernate.support.GrailsOpenSessionInViewInterceptor.postHandle(GrailsOpenSess
ionInViewInterceptor.java:66)
        at org.springframework.web.servlet.handler.WebRequestHandlerInterceptorAdapter.postHandle(WebRequestHandlerInter
ceptorAdapter.java:61)
        at org.codehaus.groovy.grails.web.servlet.GrailsDispatcherServlet.doDispatch(GrailsDispatcherServlet.java:303)
        at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719)
        at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644)
        at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:560)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)

班级定义:

class RoleDuty
{


  static belongsTo = [role:Role]

  static constraints = {
        duty(nullable: true)
  } 
    static mapping = {
          duty type:"text"
    }

  String duty;
  boolean _deleted
  static transients = ['_deleted']

  @XmlValue
  public String getDuty(){
    return duty;
  }


  String toString()
  {
      return duty;
  }

}


public class Role implements Comparable
{

    static belongsTo = [project:Project]
    static hasMany = [ roleDuties:RoleDuty]

    static mapping = {
        roleDuties cascade:"all-delete-orphan", lazy:false
    }

    List<RoleDuty> roleDuties = new ArrayList<RoleDuty>()


}

1 个答案:

答案 0 :(得分:5)

Hibernate的错误消息“在异常发生后不刷新会话”表明此会话发生了与Hibernate相关的异常,但您的代码捕获了异常并继续使用Session。 Hibernate的API声明如果Hibernate抛出异常,你必须回滚事务/关闭Session并在新的Session中做任何你想做的事。

很难确切地知道问题是来自这个堆栈跟踪和调试Hibernate错误涉及试验和错误。我建议您在查找代码之前调试代码,并找出如何避免它。