не удалось извлечь ResultSet org.hibernate.exception.SQLGrammarException - PullRequest
0 голосов
/ 24 апреля 2018

Я не могу получить результат, выполняется запрос на создание, но после этого преобразование в список не работает.Пожалуйста, помогите мне решить эту проблему.почему он не преобразуется в список, я не могу получить результат, выполняется запрос на создание, но после этого преобразование в список не работает.Пожалуйста, помогите мне решить эту проблему.почему он не преобразуется в список

Tablescript

CREATE TABLE Answer(
answerId   INTEGER,
questionId   INTEGER NOT NULL,
userId varchar2(40) NOT NULL,
answerString VARCHAR2(400) NOT NULL,
CONSTRAINT pk_Answer_answerId PRIMARY KEY(answerId)
);

класс бина

public class Answer {
private Integer answerId;
private Integer questionId;
private String userId;
private String answerString;
private String message;

public Integer getAnswerId() {
    return answerId;
}

public void setAnswerId(Integer answerId) {
    this.answerId = answerId;
}

public String getAnswerString() {
    return answerString;
}

public void setAnswerString(String answerString) {
    this.answerString = answerString;
}

public String getMessage() {
    return message;
}

public void setMessage(String message) {
    this.message = message;
}

public Integer getQuestionId() {
    return questionId;
}

public void setQuestionId(Integer questionId) {
    this.questionId = questionId;
}

public String getUserId() {
    return userId;
}

public void setUserId(String userId) {
    this.userId = userId;
}}

Метод контроллера:

$scope.tagForm.getAnswer = function(val) {
    alert("hi");
    window.location = "#/answer";
    $scope.tagForm.ans = null;
    var data = JSON.stringify($scope.tagForm);
    $http.post(URI + "tag/ans/"+val,data).then(function(response) {
        alert("hey");
        //var string=response.data;
        //var formattedString = string.join("\n");
        //$scope.askForm.message =formattedString;
        $scope.tagForm.ans =response.data;
        //alert($scope.tagForm.message);
    }, function(response) {
        $scope.tagForm.message = null;
    });
    };



@SuppressWarnings({ "unchecked", "unused" })
public Map<Integer, String> getAnswer(Integer question) throws Exception {
    Map<Integer, String> quesString = null;
    SessionFactory sessionFactory = null;
    Session session = null;
    List<AnswerEntity> custList1 = new ArrayList<AnswerEntity>();
    try {
        quesString = new LinkedHashMap<Integer, String>();
        sessionFactory = HibernateUtility.createSessionFactory();
        session = sessionFactory.openSession();
        AnswerEntity tag = new AnswerEntity();
        // Question q=new Question();
        // q.setTagId(question);
        // ques.setQuestionString(question.getQuestionString());
        System.out.println("dao" + question);

        // session.persist(ques);

        // session.getTransaction().begin();
        System.out.println("before query exec");
        Query query = session
                .createQuery("from AnswerEntity where questionId=?");
        query.setInteger(0, question);
        System.out.println(query);
        System.out.println("after query exec");
        custList1 = query.list();
        System.out.println(custList1.size());
        // List list = query.list();
        for (AnswerEntity tagEntity : custList1) {
            // System.out.println("Question ID=>"+tagEntity.getQuestionId()+"\nQuestion String=>"+tagEntity.getQuestionString());
            // List<String> newList = new ArrayList<String>();
            Answer a = new Answer();
            a.setQuestionId(tagEntity.getQuestionId());
            a.setAnswerString(tagEntity.getAnswerString());
            // newList.addAll(getTag(tagEntity.getQuestionId()));
            // String a=String.valueOf(tagEntity.getQuestionId());
            quesString.put(a.getQuestionId(), a.getAnswerString());

            // quesString.add(a);
            // quesString.addAll(newList);

        }
        // session.getTransaction().commit();

    } catch (HibernateException exception) {
        exception.printStackTrace();
        DOMConfigurator.configure("src/com/infy/resources/log4j.xml");
        Logger logger = Logger.getLogger(this.getClass());
        logger.error(exception.getMessage(), exception);
        throw new Exception("DAO.TECHNICAL_ERROR");
    } catch (Exception exception) {
        exception.printStackTrace();
        DOMConfigurator.configure("src/com/infy/resources/log4j.xml");
        Logger logger = Logger.getLogger(this.getClass());
        logger.error(exception.getMessage(), exception);
        throw exception;
    } finally {
        if (session.isOpen() || session != null) {
            session.close();
        }
    }
    return quesString;
}

errorlog

org.hibernate.exception.SQLGrammarException: не удалось извлечь ResultSet в org.hibernate.exception.internal.SQLExceptionTypeDelegate.convert (SQLExceptionTypeDelegate.java:80) в org.hibernate.exception.Sterver .Ster.преобразовать (StandardSQLExceptionConverter.java:49) в org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert (SqlExceptionHelper.java:126) в org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert: Sqljjjjв org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.extract (ResultSetReturnImpl.java:91) в org.hibernate.loader.Loader.getResultSet (Loader.java:2066) в org.hibernate.loader.Quader.Loader..java: 1863) в org.hibernate.loader.Loader.executeQueryStatement (Loader.java:1839) в org.hibernate.loader.Loader.doQuery (Loader.java: 910) в org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections (Loader.java:355) в org.hibernate.loader.Loader.doList (Loader.java:2554) в org.hibernate.loader.Loader.doList (Loader .doList.Java: 2540) в org.hibernate.loader.Loader.listIgnoreQueryCache (Loader.java:2370) в org.hibernate.loader.Loader.list (Loader.java:2365) в org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:497) в org.hibernate.hql.internal.ast.QueryTranslatorImpl.list (QueryTranslatorImpl.java:387) в org.hibernate.engine.query.spi.HQLQueryPlan.performList (HQLQueryPlan)org.hibernate.internal.SessionImpl.list (SessionImpl.java:1300) в org.hibernate.internal.QueryImpl.list (QueryImpl.java:103) в com.infy.dao.TagDAOImpl.getAnswer (TagDAOImpl.java2)в com.infy.service.TagServiceImpl.getAnswer (TagServiceImpl.java:55) в com.infy.api.TagAPI.fetchTagList2 (TagAPI.java:65) в sun.reflect.NativeMethodAccessorImpl.invoke0.NativeMethodAccessorImpl.invoke (Неизвестный источник)at sun.reflect.DelegatingMethodAccessorImpl.invoke (Неизвестный источник) в java.lang.reflect.Method.invoke (Неизвестный источник) в org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory $ 1.etjjInFFпо адресу org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher $ 1.run (AbstractJavaResourceMethodDispatcher.java:144) по адресу org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethoj.isDate ()glassfish.jersey.server.model.internal.jersey.server.model.ResourceMethodInvoker.invoke (ResourceMethodInvoker.java:389) в org.glassfish.jersey.server.model.ResourceMethodInvoker.apply (ResourceMethodInvoker.java:347) в org.glassfish.jersey.server.model.ResourceMethodInvoker.apply (ResourceMethodInvoker.java:102) в org.glassfish.jersey.server.ServerRuntime в $ 2.run (ServerRuntime.java:31).glassfish.jersey.internal.Errors $ 1.call (Errors.java:271) в org.glassfish.jersey.internal.Errors $ 1.call (Errors.java:267)в org.glassfish.jersey.internal.Errors.process (Errors.java:315) в org.glassfish.jersey.internal.Errors.process (Errors.java:297) в org.glassfish.jersey.internal.Errors.process(Errors.java:267) в org.glassfish.jersey.process.internal.RequestScope.runInScope (RequestScope.java:317) в org.glassfish.jersey.server.ServerRuntime.process (ServerRuntime.java:298) в орг.glassfish.jersey.server.ApplicationHandler.handle (ApplicationHandler.java:1154) в org.glassfish.jersey.servlet.WebComponent.serviceImpl (WebComponent.java:471) в org.glassfish.jersey.servlet.WebComponent.service (WebComponent.service.Java: 425) в org.glassfish.jersey.servlet.ServletContainer.service (ServletContainer.java:383) в org.glassfish.jersey.servlet.ServletContainer.service (ServletContainer.java:336) в org.glassfish.jersey.servlet.ServletContainer.service (ServletContainer.java:223) в org.apache.catalina.core.ApplicationFilterChain.internalDoFilter (ApplicationFilterChain.java:303) в org.apache.catalina.core.ApplicationFilterChain.doFilter (ApplicationFilterChain.java:208) в org.apache.tomcat.websocket.server.WsFilter.doFilter (WsFilter.java:52) в org.apache.catalina.core.ApplicationFilterChain.internalFilterFilter (1)в org.apache.catalina.core.ApplicationFilterChain.doFilter (ApplicationFilterChain.java:208) в org.apache.catalina.core.StandardWrapperValve.invoke (StandardWrapperValve.java:220) в org.apache.kevetatatataina(StandardContextValve.java:122) в org.apache.catalina.authenticator.AuthenticatorBase.invoke (AuthenticatorBase.java:505) в org.apache.catalina.core.StandardHostValve.invoke (StandardHostValve.javag1: 70).catalina.valves.ErrorReportValve.invoke (ErrorReportValve.java:103) в org.apache.catalina.valves.AccessLogValve.invoke (AccessLogValve.java:957) в org.apache.catalina.core.StandardEngineValve.jpg116) в org.apache.catalina.connector.CoyoteAdapter.service (CoyoteAdapter.java:423) в org.apache.coyote.http11.AbstractHttp11Processor.process (AbstractHttp11Processor.java:1079) в org.apache.coyote.AbstractProtocol $ AbstractConnectionHandler.process (AbstractProtocol.java:620) в org.apache.tomcat.util.net.JIoProorpoint $JIoEndpoint.java:316) по адресу java.util.concurrent.ThreadPoolExecutor.runWorker (неизвестный источник) по адресу java.util.concurrent.ThreadPoolExecutor $ Worker.run (неизвестный источник) по адресу org.apache.tomcat.util.threads.WasRun.run (TaskThread.java:61) at java.lang.Thread.run (Неизвестный источник) Причина: java.sql.SQLSyntaxErrorException: ORA-00904: «ANSWERENTI0 _». «MESSAGE»: неверный идентификатор

Класс ответаEntity

public class AnswerEntity {
@Id
@GeneratedValue(generator = "generatorName")
private Integer answerId;
private Integer questionId;
private String userId;
private String answerString;
private String message;

public Integer getAnswerId() {
    return answerId;
}

public void setAnswerId(Integer answerId) {
    this.answerId = answerId;
}

public String getAnswerString() {
    return answerString;
}

public void setAnswerString(String answerString) {
    this.answerString = answerString;
}

public String getMessage() {
    return message;
}

public void setMessage(String message) {
    this.message = message;
}

public Integer getQuestionId() {
    return questionId;
}

public void setQuestionId(Integer questionId) {
    this.questionId = questionId;
}

public String getUserId() {
    return userId;
}

public void setUserId(String userId) {
    this.userId = userId;
}}

1 Ответ

0 голосов
/ 24 апреля 2018

У вас есть свойство message в вашем классе сущностей, но у вас нет соответствующего столбца в базе данных.Это четко определено в трассировке стека:

ORA-00904: "ANSWERENTI0_"."MESSAGE": invalid identifier

Вам нужно либо создать столбец, если вы хотите сохранить эту информацию в базе данных, либо удалить ее из класса сущностей, либо пометить ее как @Transient, чтобы задать спящий режимигнорировать его в запросах SQL, как в этом вопросе: Заставить hibernate игнорировать переменные класса, которые не отображаются

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...