5

hqlを使用する代わりにネイティブSQLクエリを作成し、問題に直面しました

宣言された序数パラメーターの数を超える位置。序数パラメータは 1 から始まることに注意してください。ポジション: 1

<sql-query name="GET_ARRAY_MAX_POINT_QUESTION">
    <![CDATA[
        select TEST.TEST_ID as testId, TEST.VERSION_ID as versionId,
        PASSED_TEST.RESULT as userResult,
        PASSED_TEST.TIME_COMPLITED as timeComplited,
        sum(COMPLEXITY) as maxTestResult from QUESTION
        JOIN TEST_QUESTION ON QUESTION.QUESTION_ID = TEST_QUESTION.QUESTION_ID
        JOIN TEST ON TEST.TEST_ID=TEST_QUESTION.TEST_ID
        JOIN PASSED_TEST ON TEST.TEST_ID=PASSED_TEST.TEST_ID
        AND TEST.VERSION_ID=PASSED_TEST.VERSION_ID
        WHERE TEST.SUBJECT_ID = ?
        AND PASSED_TEST.USER_ID = ?
        GROUP BY PASSED_TEST.TEST_EVENT_ID
        ]]>
    </sql-query>

そしてDAO

return session
                .createSQLQuery(GET_ARRAY_MAX_POINT_QUESTION_NAME_QUERY)
                .addScalar(TEST_ID_RESULT_PARAM, StandardBasicTypes.LONG)
                .addScalar(VERSION_ID_RESULT_PARAM, StandardBasicTypes.LONG)
                .addScalar(USER_RESULT_PARAM, StandardBasicTypes.DOUBLE)
                .addScalar(MAX_TEST_RESULT_PARAM, StandardBasicTypes.DOUBLE)
                .addScalar(TIME_COMPLITED_RESULT_PARAM, StandardBasicTypes.DATE)
                .setParameter(0, subjectId)
                .setParameter(1, userId)
                .setResultTransformer(
                        Transformers.aliasToBean(PassedTestStatistic.class))
                .list();

私はそれを読み、//JPA specification. Only positional parameter binding may be portably used for native queries.その休止状態は最初のインデックスとして0を使用します。

スタックトレース

Caused by: org.hibernate.QueryParameterException: Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based! Position: 1
    at org.hibernate.engine.query.spi.ParameterMetadata.getOrdinalParameterDescriptor(ParameterMetadata.java:80)
    at org.hibernate.engine.query.spi.ParameterMetadata.getOrdinalParameterExpectedType(ParameterMetadata.java:86)
    at org.hibernate.internal.AbstractQueryImpl.determineType(AbstractQueryImpl.java:444)
    at org.hibernate.internal.AbstractQueryImpl.setParameter(AbstractQueryImpl.java:416)
    at by.bsuir.testapp.database.hibernate.PassedTestHibernateDAO.getDataForPassedTestStatisticGraph(PassedTestHibernateDAO.java:73)
    at by.bsuir.testapp.service.PassedTestServiceImpl.getDataForPassedTestStatisticGraph(PassedTestServiceImpl.java:58)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:319)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
    at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
    at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202)
    at $Proxy28.getDataForPassedTestStatisticGraph(Unknown Source)
    at by.bsuir.testapp.controller.StatisticPassedTest.createLinearModel(StatisticPassedTest.java:61)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.apache.el.parser.AstValue.invoke(AstValue.java:262)
    at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:278)

//アップデート

興味深いことに、クエリの数値を設定すると

WHERE TEST.SUBJECT_ID = 1
        AND PASSED_TEST.USER_ID = 1

私は得る

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'GET_ARRAY_MAX_POINT_QUESTION' at line 1 

しかし、MySQL では成功した結果が得られます。

どうすればこの問題を解決できますか?

4

5 に答える 5

7

あなたが呼ぶ

session.createSQLQuery 

でも私はあなたが電話する必要があると信じています

session.getNamedQuery 

名前付きクエリを使用する場合。

于 2012-12-12T09:10:58.923 に答える
2

チェックしてください

.setParameter(1, subjectId)
.setParameter(2, userId)

例外トレースでは、順序パラメーターは1ベースであると示されています。

于 2012-12-08T10:45:45.367 に答える
1

位置パラメータを提供する代わりに、名前付きパラメータを使用してみてください。

たとえば。

session
  .createSQLQuery("update table1 set variable = variable + 1 where id = :id")
  .setParameter("id", someId)
  .executeUpdate();

ネイティブ SQL クエリは、位置パラメータと名前付きパラメータをサポートしています。

次の名前付き SQL クエリを参照してください: http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/querysql.html#d0e13930

于 2012-12-08T13:18:17.090 に答える
1

ソースを見る

createSQLQuery(GET_ARRAY_MAX_POINT_QUESTION_NAME_QUERY)

次のように、ネイティブ クエリの実際の名前を含む文字列を指す変数が必要です。

GET_ARRAY_MAX_POINT_QUESTION_NAME_QUERY = "GET_ARRAY_MAX_POINT_QUESTION"

ここに表示されるエラー:

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'GET_ARRAY_MAX_POINT_QUESTION' at line 1

createSqlQuery が名前でネイティブ クエリを見つけていないことを示しますが、代わりに、s.createSqlQuery("Select * from...") に入れたかのように生の SQL として "GET_ARRAY_MAX_POINT_QUESTION" という名前を実行しようとしています。ここのドキュメントでは、ネイティブのクエリであっても、名前付きクエリを検索するには getNamedQuery を使用する必要があることがわかります。

于 2012-12-14T23:03:16.560 に答える