hql 占位符_hibernate查询语句hql中的占位符?参数与命名参数:name设值方式搞混
发布日期:2022-02-03 13:17:01 浏览次数:6 分类:技术文章

本文共 1039 字,大约阅读时间需要 3 分钟。

先贴出异常

Struts has detected an unhandled exception:

Messages:

Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based! Position: 1

File: org/hibernate/engine/query/spi/ParameterMetadata.java

Stacktraces

org.hibernate.QueryParameterException: Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based! Position: 1

代码:

//定义hql

String hql = "from Book book where "

+ "book.bookType like :queryArgs or "

+ "book .bookNum like :queryArgs or "

+ "book.bookName like :queryArgs or "

+ "book.bookAuthor like :queryArgs "

+ "order by book.bookType, book .bookNum, book.bookAuthor, book.bookName";

//dao中设值

Query query = sessionFactory.getCurrentSession().createQuery(hql);

for (int i = 0; i < objects.length; i++) {

query.setParameter(i, objects[i]);

}

原因:

异常上说占位符索引越界(溢出),原因是我定义的hql中根本没有占位符“?”,我用的是命名参数,应该通过setString(paraName,paraValue)或者setParameter(paraName,paraValue)的方式来设值,我却用setParameter(int arg0, Object arg1)来设值,所以就报错了!

解决办法:

对于我这个,我通过吧:queryArgs全部替换成?的方式。

转载地址:https://blog.csdn.net/weixin_34759094/article/details/113567824 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:联想笔记本mysql启动不了_目前安装并启动mysql遇到的问题:
下一篇:mysql加索引原理_添加mysql索引的3条原则

发表评论

最新留言

路过,博主的博客真漂亮。。
[***.116.15.85]2024年04月16日 00时38分12秒