0

私は非常に奇妙な問題に直面しており、それを解決する方法が見つかりません。intellij の HQL Console で次の 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な更新クエリを回避することです。データベースからオブジェクトをロードし、フィールドを変更してから、Hibernateオブジェクトを更新するだけです。

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 に答える