2010.03.30————hql语句处理时间问题

本文探讨了使用HQL进行日期范围查询时遇到的语法异常问题,并提供了两种不同的解决方案。一种是直接在HQL字符串中拼接日期参数,另一种则是采用预编译方式通过占位符来传递参数。

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

2010.03.30————hql语句处理时间问题
public List<CP_GongCheng> getByDate(Date start,Date end){
String hql = "from CP_GongCheng o where o.kg_date between "+start+" and "+end;
return (List<CP_GongCheng>)this.getHibernateTemplate().find(hql);
}
当我这样写时,就会报异常:
org.hibernate.hql.ast.QuerySyntaxException: unexpected token: Jan near line 1, column 54


而当我像下面写时,就没有问题,貌似必须把参数和hql分开,原因我也不知道
public List<CP_GongCheng> getByDate(Date start,Date end){
String hql = "from CP_GongCheng o where o.kg_date between ? and ?";
Object[] values = {start,end};
return (List<CP_GongCheng>)this.getHibernateTemplate().find(hql,values);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值