0

我有一个 namedQuery 通过它传递 2 个参数,如下所示,

ArrayList idName= new ArrayList();
     idName.add(id); --int
     idName.add(ABC); --String

我将这个对象传递给namedQuery,如下所示:

return getHibernateTemplate().findByNamedQuery("findIDAndName", idName);

我的 hbm.xml 有这个查询,

  <sql-query name="findIDAndName">
      <return alias="IdNamePmt" class="com.app.Grp.model.IdNamePmt"/>
      <![CDATA[select * from PMT.CSE_NME_VW where PMT_ID=? and PMT_NAME=?]]>
    </sql-query>

当我运行应用程序时,出现以下错误:

org.hibernate.QueryException: Expected positional parameter count: 2, actual parameters: [[7, ABC]] [select * from PMT.CSE_NME_VW where PMT_ID=? and PMT_NAME=?]
    at org.hibernate.impl.AbstractQueryImpl.verifyParameters(AbstractQueryImpl.java:367)
    at org.hibernate.impl.SQLQueryImpl.verifyParameters(SQLQueryImpl.java:228)
    at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:172)

我已经传递了 2 个参数,我的 'where' 子句也需要 2 个参数。怎么了?任何例子高度赞赏?

4

1 回答 1

0

我相信应该是

return getHibernateTemplate().findByNamedQuery("findIDAndName", idName.toArray());
于 2012-11-09T20:39:59.447 回答