我有一个 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 个参数。怎么了?任何例子高度赞赏?