Hibernate中设置query参数的方法

</pre>1.用hibernate建议的命名参数方法(推荐):<p></p><p></p><pre code_snippet_id="218425" snippet_file_name="blog_20140305_1_8264782" name="code" class="java">		List<Student> list = session.createQuery("from Student where dept=:sdept and age>:sage and sex=:sex")
				.setString("sdept", "计算机学院")
				.setParameter("sex", "男")
				.setInteger("sage", 20)
				.list();
2.用已经废弃的方法:

		List<Student> list = session.createQuery("from Student as s where s.age>? and s.dept=?")
				.setInteger(0, 20)
				.setString(1, "<span style="font-family: Arial, Helvetica, sans-serif;">计算机学院</span>")
				.list();
3.JPA-Style占位符方法:

		List<Student> list = session.createQuery("from Student as s where s.age>?0 and s.dept=?1")
				.setInteger(0, 20)
				.setString(1, "计软院")
				.list();	//参数绑定
此方法试过多次未果,都会抛出异常:

java.lang.IllegalArgumentException: No positional parameters in query: from Student where age>?0 and dept=?1

不知道这个哪里有错?求解



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值