문제
내 매핑 XML 파일에 다음 클래스가 정의되어 있습니다.
<class name="com.data.StateRefData" table="STATE_REF">
<composite-id name="primaryKey" class="com.data.StateRefPkData">
<key-property name="countryCode">
<column name="COUNTRY_CODE" />
</key-property>
<key-property name="state">
<column name="STATE" />
</key-property>
</composite-id>
<property name="dialingCode" column="DIALING_CODE"></property>
<property name="isActive" column="IS_ACTIVE"></property>
<property name="localeCode" column="LOCALE_CODE"></property>
<property name="stName" column="ST_NAME"></property>
</class>
이 클래스의 이름 슈리를 정의하려고합니다. 내가 시도한 것은 다음과 같습니다.
<query name="findState">
<![CDATA[ from
com.data.StateRefData
WHERE primaryKey = :primaryKey
]]>
</query>
내가 이것을 호출하는 데 사용하는 Java 코드는 다음과 같습니다.
Query stateQuery = null;
List<StateRefData> stateList = null;
StateRefPkData primaryKey = new StateRefPkData();
StateRefData filter = new StateRefData();
primaryKey.setCountryCode(inCountryCode);
primaryKey.setState(inStateProvince);
filter.setPrimaryKey(primaryKey);
stateQuery = session.getNamedQuery("findState");
stateQuery.setProperties(filter);
그러나 "StateQuery.list ()"부분에서 이러한 오류가 바로 얻습니다.
[ERROR JDBCExceptionReporter:72] Line 1: Incorrect syntax near ','.
org.hibernate.exception.SQLGrammarException: could not execute query
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:59)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
at org.hibernate.loader.Loader.doList(Loader.java:1596)
at org.hibernate.loader.Loader.list(Loader.java:1577)
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:395)
at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:271)
at org.hibernate.impl.SessionImpl.list(SessionImpl.java:844)
at org.hibernate.impl.QueryImpl.list(QueryImpl.java:74)
합성물로 지명 된 Query를 사용하는 방법에 대한 아이디어가 있습니까?
메모: 나는 또한 시도했다 :
stateQuery.setParameter("primaryKey", primaryKey);
그리고 여전히 오류가 있습니다.
신규 (편집) :코드를 실행할 때 발생하는 HQL 및 SQL은 다음과 같습니다.
[DEBUG AST:223] --- HQL AST ---
\-[QUERY] 'query'
+-[SELECT_FROM] 'SELECT_FROM'
| \-[FROM] 'from'
| \-[RANGE] 'RANGE'
| +-[DOT] '.'
| | +-[DOT] '.'
| | | +-[DOT] '.'
| | | | +-[DOT] '.'
| | | | | +-[IDENT] 'com'
| | | \-[IDENT] 'data'
| | \-[IDENT] 'StateRefData'
| \-[ALIAS] 'd'
\-[WHERE] 'WHERE'
\-[EQ] '='
+-[DOT] '.'
| +-[IDENT] 'd'
| \-[IDENT] 'primaryKey'
\-[COLON] ':'
\-[IDENT] 'primaryKey'
[DEBUG AST:193] --- SQL AST ---
\-[SELECT] QueryNode: 'SELECT' querySpaces (STATE_REF)
+-[SELECT_CLAUSE] SelectClause: '{derived select clause}'
| +-[SELECT_EXPR] SelectExpressionImpl: 'statere0_.COUNTRY_CODE as COUNTRY1_, statere0_.STATE as STATE' {FromElement{explicit,not a collection join,not a fetch join,fetch non-lazy properties,classAlias=d,role=null,tableName=STATE_REF,tableAlias=statere0_,colums={,className=com.data.StateRefData}}}
| \-[SQL_TOKEN] SqlFragment: 'statere0_.DIALING_CODE as DIALING3_60_, statere0_.IS_ACTIVE as IS4_60_, statere0_.LOCALE_CODE as LOCALE5_60_, statere0_.ST_NAME as ST6_60_'
+-[FROM] FromClause: 'from' FromClause{level=1, fromElementCounter=1, fromElements=1, fromElementByClassAlias=[d], fromElementByTableAlias=[statere0_], fromElementsByPath=[], collectionJoinFromElementsByPath=[], impliedElements=[]}
| \-[FROM_FRAGMENT] FromElement: 'STATE_REF statere0_' FromElement{explicit,not a collection join,not a fetch join,fetch non-lazy properties,classAlias=d,role=null,tableName=STATE_REF,tableAlias=statere0_,colums={,className=com.data.StateRefData}}
\-[WHERE] SqlNode: 'WHERE'
\-[EQ] SqlNode: '='
+-[DOT] DotNode: '(statere0_.COUNTRY_CODE, statere0_.STATE)' {propertyName=primaryKey,dereferenceType=2,propertyPath=primaryKey,path=d.primaryKey,tableAlias=statere0_,className=com.data.StateRefData,classAlias=d}
| +-[ALIAS_REF] IdentNode: '(statere0_.COUNTRY_CODE, statere0_.STATE)' {alias=d, className=com.data.StateRefData, tableAlias=statere0_}
| \-[IDENT] IdentNode: 'primaryKey' {originalText=primaryKey}
\-[NAMED_PARAM] SqlNode: '?'
해결책
SQL 로깅을 켜서 생성되는 SQL 코드를 제공 할 수 있습니까?
log4j.properties를 사용하는 경우 샘플은 다음과 같습니다.
log4j.logger.org.hibernate.sql = 디버그
업데이트 #1
기존 쿼리가 왜 작동하지 않는지 잘 모르겠지만, 이것도 시도해야합니다. Pojo를 전달하면 다른 코드를 업데이트 할 필요가 없습니다.
<query name="findState">
<![CDATA[ from
com.data.StateRefData
WHERE primaryKey.countryCode = :countryCode AND primaryKey.state = :state
]]>
</query>
다른 팁
IncountryCode 또는 InstateProvince가 비어 있거나 널이 될 가능성이 있습니까?
제휴하지 않습니다 StackOverflow