0

Hibernate を使用して開発を開始したばかりで、テーブル内の列を選択しようとしているときに問題に直面しています。「nome」という列を持つテーブルがあり、それは文字列です。私がしたいのは、テーブル内のこの列のすべての値を取得することだけです。このために、メソッドを作成しました:

public List<String> obtemNomePorQuery(String query) {

        EntityManager manager = getEntityManager();

        Session session = manager.unwrap(Session.class);    

        List<String> listResult = (List<String>) session.createQuery(query).list();
        manager.close();

        return listResult;
    }

この場合、クエリ パラメータで「select nome from lojas」を渡しています。MySQL でこのクエリを実行すると、必要なものがすべて返されます。Hibernate を使用すると、次のログが取得されます。

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.hibernate.hql.internal.ast.QuerySyntaxException: lojas is not mapped [select nome from lojas]
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:656)
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:549)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
root cause

org.hibernate.hql.internal.ast.QuerySyntaxException: lojas is not mapped [select nome from lojas]
    org.hibernate.hql.internal.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:180)
    org.hibernate.hql.internal.ast.tree.FromElementFactory.addFromElement(FromElementFactory.java:110)
    org.hibernate.hql.internal.ast.tree.FromClause.addFromElement(FromClause.java:93)
    org.hibernate.hql.internal.ast.HqlSqlWalker.createFromElement(HqlSqlWalker.java:326)
    org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.fromElement(HqlSqlBaseWalker.java:3252)
    org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.fromElementList(HqlSqlBaseWalker.java:3141)
    org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.fromClause(HqlSqlBaseWalker.java:694)
    org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.query(HqlSqlBaseWalker.java:550)
    org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.selectStatement(HqlSqlBaseWalker.java:287)
    org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.statement(HqlSqlBaseWalker.java:235)
    org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:248)
    org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:183)
    org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:136)
    org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:101)
    org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:80)
    org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:119)
    org.hibernate.internal.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:214)
    org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:192)
    org.hibernate.internal.SessionImpl.createQuery(SessionImpl.java:1537)
    com.puccamp.projetofinal.persistence.Dao.obtemNomePorQuery(Dao.java:198)
    com.puccamp.projetofinal.controller.LojaController.gerenciaLoja(LojaController.java:63)
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    java.lang.reflect.Method.invoke(Unknown Source)
    org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:176)
    org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:426)
    org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:414)
    org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:790)
    org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719)
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644)
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:549)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:728)

私は間違って何をしている可能性がありますか?

4

1 に答える 1

1

使用しているメソッドは、SQL ではなく HQL を想定しています。lojasテーブルに関連付けられた永続オブジェクトはありますか? そうでない場合、HQL はオプションではなく、代わりにデータベースへのネイティブ接続を取得して SQL を実行する必要があります。createSQLQuery(String queryString)の方法を試しましたSessionか?Javadoc は次のとおりです。http://docs.jboss.org/hibernate/orm/3.5/javadoc/org/hibernate/Session.html

于 2013-05-04T00:20:02.320 に答える