2013-06-19 2 views
1

이 쿼리는 작동시키려는 더 큰 쿼리의 작은 버전입니다. 쿼리를 실행할 때 다음과 같은 오류가 발생합니다. 유죄 칼럼을 찾기 위해 할 수있는만큼 많은 쿼리를 제거하려고 시도했지만 성공하지는 못했습니다. 나는 3.6 최대 절전 모드, 봄 3.2.1 사용하고 오라클 11g있어Hibernate createSQLquery에 잘못된 열 이름 오류가 발생했습니다.

Caused by: java.sql.SQLException: Invalid column name 
    at oracle.jdbc.driver.OracleStatement.getColumnIndex(OracleStatement.java:3711) 
    at oracle.jdbc.driver.OracleResultSetImpl.findColumn(OracleResultSetImpl.java:2763) 
    at oracle.jdbc.driver.OracleResultSet.getBigDecimal(OracleResultSet.java:368) 
    at org.hibernate.type.descriptor.sql.DecimalTypeDescriptor$2.doExtract(DecimalTypeDescriptor.java:62) 
    at org.hibernate.type.descriptor.sql.BasicExtractor.extract(BasicExtractor.java:64) 

검색어 :

String query = "SELECT d.ID as {d.id}, d.DETAIL_ORDER as {d.detailOrder}, g.ID as {g.id}, g.NAME as {g.name} " + 
    "FROM EVAL_MASTER_EVAL_DETAIL d " + 
    "JOIN EVAL_QUESTION_GROUP g ON d.GROUP_ID = g.ID " + 
    "WHERE d.ACTIVE = 'Y' " + 
    "AND d.MASTER_EVAL_ID = :evalId" + 
    " ORDER BY d.DETAIL_ORDER ASC"; 

    details = session.createSQLQuery(query).addEntity("d", EvalMasterEvalDetail.class) 
    .addEntity("g", EvalQuestionGroup.class).setParameter("evalId", evalId).list(); 

결과 최대 절전 모드 검색어 :

Hibernate: SELECT d.ID as ID29_0_, d.DETAIL_ORDER as DETAIL5_29_0_, g.ID as ID34_1_, g.NAME as NAME34_1_ FROM EVAL_MASTER_EVAL_DETAIL d JOIN EVAL_QUESTION_GROUP g ON d.GROUP_ID = g.ID WHERE d.ACTIVE = 'Y' AND d.MASTER_EVAL_ID = ? ORDER BY d.DETAIL_ORDER ASC 

매핑 (이름을 확인하기 위해)

<hibernate-mapping> 
     <class name="org.anes.surveys.domain.EvalMasterEvalDetail" table="EVAL_MASTER_EVAL_DETAIL"> 
      <id name="id" type="big_decimal"> 
       <column name="ID" precision="22" scale="0" /> 
       <generator class="sequence-identity" > 
        <param name="sequence">EVAL_MASTER_EVAL_DETAIL_SEQ</param> 
       </generator> 
      </id> 
      <many-to-one name="evalQuestionGroup" class="org.anes.surveys.domain.EvalQuestionGroup" fetch="select"> 
       <column name="GROUP_ID" precision="22" scale="0" /> 
      </many-to-one> 
     <many-to-one name="evalMasterEvaluation" class="org.anes.surveys.domain.EvalMasterEvaluation" fetch="select"> 
     <column name="MASTER_EVAL_ID" precision="22" scale="0" not-null="true" /> 
    </many-to-one> 
      <property name="detailOrder" type="big_decimal"> 
       <column name="DETAIL_ORDER" precision="22" scale="0" not-null="true" /> 
      </property> 
      <property name="active" type="string"> 
       <column name="ACTIVE" length="1" not-null="true" /> 
      </property> 
     </class> 
    </hibernate-mapping> 

<hibernate-mapping> 
    <class name="org.anes.surveys.domain.EvalQuestionGroup" table="EVAL_QUESTION_GROUP"> 
     <id name="id" type="big_decimal"> 
      <column name="ID" precision="22" scale="0" /> 
      <generator class="sequence-identity" > 
       <param name="sequence">EVAL_QUESTION_GROUP_SEQ</param> 
      </generator> 
     </id> 
     <property name="name" type="string"> 
      <column name="NAME" not-null="true" /> 
     </property> 
     <set name="evalMasterEvalDetails" table="EVAL_MASTER_EVAL_DETAIL" inverse="true" lazy="true" fetch="select"> 
      <key> 
       <column name="GROUP_ID" precision="22" scale="0" /> 
      </key> 
      <one-to-many class="org.anes.surveys.domain.EvalMasterEvalDetail" /> 
     </set> 
    </class> 
</hibernate-mapping> 

편집 : 다음을 시도했지만 여전히 잘못된 열 오류가 발생합니다. ACTIVE & d.active는 문자열입니다.

String query = "SELECT ACTIVE as {d.active} " + 
       "FROM EVAL_MASTER_EVAL_DETAIL"; 
details = session.createSQLQuery(query).addEntity("d", EvalMasterEvalDetail.class).list(); 

String query = "SELECT d.ID " + 
     "FROM EVAL_MASTER_EVAL_DETAIL d "; 
details = session.createSQLQuery(query).addEntity("d", EvalMasterEvalDetail.class).list(); 

String query = "SELECT ID " + 
     "FROM EVAL_MASTER_EVAL_DETAIL"; 
details = session.createSQLQuery(query).addEntity("d", EvalMasterEvalDetail.class).list(); 

이 작동하지만, 난 단지 스칼라 값을 얻을 :

String query = "SELECT ID " + 
     "FROM EVAL_MASTER_EVAL_DETAIL"; 
details = session.createSQLQuery(query).list(); 
+0

하나의 열만 반환하도록 쿼리를 실행 해 보았습니까? –

+0

당신은 매핑에'MASTER_EVAL_ID'을 가지고 있지 않습니다. 그리고 그것을'AND d.MASTER_EVAL_ID = : evalId'에서 사용하고 있습니다. 그럴 수도 있습니다. –

+0

생성 된 SQL을 Oracle에 직접 실행하십시오. – Smertokogt

답변

4

다음과 같은 결과가 있습니다.

- 난

이 -Created/정의 내 쿼리의 결과를 보유 할 getter 및 setter와 새 도메인 클래스 (클래스 필드를 포함 (객체 필드 대신 DB 열을 참조) 대신 내 네이티브 SQL의 HQL을 사용 5 다른 개체/테이블)에서

public class EvalForm { 
    private BigDecimal detailId; 
    private BigDecimal detailOrder; 
    private BigDecimal groupId; 
    private String groupName; 
} 

열 별칭

String query = "SELECT d.id as detailId, d.detailOrder as detailOrder, g.id as groupId, g.name as groupName.... 

t을 가리 키도록 걸러 setResultTransformer 나의 새로운 클래스의 필드 이름을 - 중고 o 새 클래스

details = session.createQuery(query).setParameter("evalId", evalId).setResultTransformer(Transformers.aliasToBean(EvalForm.class)).list(); 

결과가 좋지 않습니까? JSON 출력에 완벽합니다.

[{"detailId":44,"detailOrder":0,"groupId":128,"groupName":"My dope name"},{"detailId":42,"detailOrder":1,"groupId":68,"groupName":"qGroup AJAX"},{"detailId":81,"detailOrder":2,"groupId":68,"groupName":"qGroup AJAX"}] 
0

제거 모든 열 별칭. 즉 변화 :

d.ID as {d.id} 

단지

d.ID 

나는 그런 HQL 구문을 본 적이 없습니다. 유효 할 수도 있지만 확실히 불필요합니다.

+0

별명은 java 오브젝트를 참조합니다. addEntity 문자열이 {별칭}을 참조하지 않습니까? 스칼라 값을 반환하지 않으려면 이들이 필요하다고 생각했습니다. 나는 내가 (시도와 참조없이) 시도한 몇 가지 방법으로 내 게시물을 업데이트했지만 운이 없었다. –

관련 문제