0

我面临着非常奇怪的问题,找不到解决方法。我在 intellij 的 HQL 控制台中编写了以下 HQL

update NewsEntity ne set ne.main=false where ne.main=true

堆栈跟踪

java.lang.IllegalArgumentException: node to traverse cannot be null!
 at org.hibernate.hql.ast.util.NodeTraverser.traverseDepthFirst(NodeTraverser.java:31)
 at org.hibernate.hql.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:254)
 at org.hibernate.hql.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:157)
 at org.hibernate.hql.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:111)
 at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:77)
 at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:56)
 at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:72)
 at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:133)
 at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:112)
 at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1623)
 in RemoteSessionImpl.createQuery(RemoteSessionImpl.java:50)
 in RemoteUtil.executeWithClassLoader(RemoteUtil.java:122)
 in RemoteUtil$2$1.invoke(RemoteUtil.java:81)
 in HibernateEngine.createQuery(HibernateEngine.java:142) 

当我写一个delete查询时,我没有同样的问题。

我基于以下文章HQL update query进行了此查询。但是,似乎无法弄清楚为什么我仍然遇到这个问题。

4

1 回答 1

0

ORM like 的想法Hibernate是避免此类更新查询。您只需从 db 加载对象,更改字段,然后Hibernate将对象更新为 out。

Query query = session.createQuery("from NewsEntity ne where ne.main = true");
NewsEntity newsEntity = (NewsEntity) query.uniqueResult();
newsEntity.setMain=false;
//Hibernate will update the object

如果有更多对象:

List<NewsEntity> newsEntities = (List<NewsEntity>) query.list();
for(NewsEntity entity : newsEntities)
{
 entity.setMain=false;
}

Hibernate 还支持 DML 语句,因此要执行update查询,您应该执行以下操作:

Query query = session.createQuery("your update query");
int result = query.executeUpdate();
于 2013-01-15T15:17:25.797 回答