hibernate查询语句hql中的占位符?参数与命名参数:name设值方式搞混

本文分析了一个关于Hibernate查询时出现的异常,详细解释了错误发生的原因,并提供了解决方案。主要是因为使用了不匹配的参数设置方式导致的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先贴出异常

 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://www.cnblogs.com/moxuyou/p/5494948.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值