关于在Hibernate5.3.1中HQL语句使用"?"参数占位符运行报错的问题

在Hibernate5.3.1中,使用'?'参数占位符的HQL语句会导致QueryException,提示应使用JPA-style参数。解决方法包括将'?'替换为JPA-style的ordinal参数,如'?1',并使用setParameter()方法代替过时的setInteger()。此外,可以使用别名方式写HQL语句,如':myage'和':myscore'。

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

在Hibernate5.3.1中,HQL语句使用"?"参数占位符运行报错:

Caused by: org.hibernate.QueryException: 

Legacy-style query parameters (`?`) are no longer supported; use JPA-style ordinal parameters (e.g., `?1`) instead

并且:在Query查询时:setInteger()等方法已过时:

 

解决办法:

1.将HQL语句中的"?"改为JPA-style:

String hql = "from Student where age > ?0 and score < ?1";

2.方法过时问题解决:使用setParameter():

List<Student> list = createQuery .setParameter(0, 21) .setParameter(1, 95.0) .list();

3.使用别名方式写HQL语句:

String hql = "from Student where age > :myage and score < :myscore";

 

总结:3种方式对应CODE:

// 1:将HQL语句中的"?"改为JPA-style:
String hql = "from Student where age > ?0 and score < ?1";	
			Query createQuery = session.createQuery(hql);
			List&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值