当我从表中删除所有数据时,出现奇怪的异常。自从我将 Hibernate 版本从 3.x.x 更新到 4.2.6 后,就出现了异常。
我调用从表中删除数据的 Dao 方法:
@Override
public void deleteAll()
{
EntityManager em = getEntityManager();
em.createQuery( "DELETE Document" ).executeUpdate();
}
堆栈跟踪:
12:46:03,570 ERROR ErrorCounter:50 - <AST>:0:0: unexpected end of subtree
<AST>:0:0: unexpected end of subtree
at org.hibernate.hql.internal.antlr.SqlGeneratorBase.whereClauseExpr(SqlGeneratorBase.java:1378)
at org.hibernate.hql.internal.antlr.SqlGeneratorBase.whereClause(SqlGeneratorBase.java:1272)
at org.hibernate.hql.internal.ast.exec.DeleteExecutor.<init>(DeleteExecutor.java:72)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.buildAppropriateStatementExecutor(QueryTranslatorImpl.java:535)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:201)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:138)
at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:105)
at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:80)
at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:168)
at org.hibernate.internal.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:221)
at org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:199)
at org.hibernate.internal.SessionImpl.createQuery(SessionImpl.java:1778)
at org.hibernate.ejb.AbstractEntityManagerImpl.createQuery(AbstractEntityManagerImpl.java:291)
at sun.reflect.GeneratedMethodAccessor800.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
Entity:
@Entity
@Table( name = "document" )
public class Document implements Serializable
{
@Override
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "document_id" )
private int id;
private String filename;
@Temporal( TemporalType.TIMESTAMP )
@Column( name = "file_modified_time" )
private Date fileModifiedTime;
@ManyToOne( fetch = FetchType.LAZY )
@JoinColumn( name = "attached_to_Task_fk" )
private Task attachedToTaskFk;
//Getter/Setter
}
当我向删除查询添加 where 子句时,不会发生异常。
em.createQuery( "DELETE Document d WHERE d.id > 0" ).executeUpdate();
但我不认为 Hibernate 是这样想的。
我已经检查了以下主题:
- 子树意外结束 https://stackoverflow.com/questions/2066361/hibernate-and-unexpected-end-of-subtree-exception
- Hibernate 和子树意外结束异常 https://stackoverflow.com/questions/2066361/hibernate-and-unexpected-end-of-subtree-exception
有谁知道如何解决这个问题?
这似乎是一个休眠错误 https://hibernate.atlassian.net/browse/HHH-8578该问题已在 4.2.7 和 4.3.0.Beta5 中修复。 DeleteExecutor 以前需要一个Where 子句。
您可以找到patch https://github.com/hibernate/hibernate-orm/commit/e3419f6d722a276fd846178ee59b3176a9fb0da7如果您尚未准备好升级到 4.2.7,请访问 GitHub。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)