hibernate table is not mapped [from table]
2316 ワード
hibernate、springフレームワークを使用してデータベース操作を行うと、次のエラーが発生します.
エラーの原因:OrderDao.javaではhql文が使用されているため、データベース・テーブル名ではなくエンティティ・クラス名を使用する必要があります.
この例では、OrderDao.javaの「from order where orderId=?」を「from Order where orderId=?」に変更すると、問題が解決します.
Exception in thread "main" org.hibernate.hql.internal.ast.QuerySyntaxException: order is not mapped [from order where orderId=?]
at org.hibernate.hql.internal.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:180)
at org.hibernate.hql.internal.ast.tree.FromElementFactory.addFromElement(FromElementFactory.java:110)
at org.hibernate.hql.internal.ast.tree.FromClause.addFromElement(FromClause.java:93)
at org.hibernate.hql.internal.ast.HqlSqlWalker.createFromElement(HqlSqlWalker.java:324)
at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.fromElement(HqlSqlBaseWalker.java:3420)
at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.fromElementList(HqlSqlBaseWalker.java:3309)
at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.fromClause(HqlSqlBaseWalker.java:706)
at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.query(HqlSqlBaseWalker.java:562)
at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.selectStatement(HqlSqlBaseWalker.java:299)
at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.statement(HqlSqlBaseWalker.java:247)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:250)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:185)
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 dao.impl.OrderDao.getOrderById(OrderDao.java:24)
at service.impl.OrderItemService.createOrderItem(OrderItemService.java:21)
at second.testOrder.main(testOrder.java:21)
エラーの原因:OrderDao.javaではhql文が使用されているため、データベース・テーブル名ではなくエンティティ・クラス名を使用する必要があります.
この例では、OrderDao.javaの「from order where orderId=?」を「from Order where orderId=?」に変更すると、問題が解決します.