hibernate查询使用hql时如果有参数,query就不执行了

如果没有参数Stringhql="fromEmployee";就可以查的出来,没有错误。但是有参数就会报错System.out.println("------------... 如果没有参数String hql = "from Employee";就可以查的出来,没有错误。

但是有参数就会报错
System.out.println("------------------------1");
String hql = "from Employee as e where e.username=? and password=?";
Query query = session.createQuery(hql);
System.out.println("------------------------2");
query.setString(0, username);
query.setString(1,password);
List list = query.list();
System.out.println("----------------size:" + list.size());
Employee employee = (Employee)list.get(0);

控制台不会报错,页面报错如下
HTTP Status 500 -
type Exception report
message
description The server encountered an internal error that prevented it from fulfilling this request.
exception
java.lang.reflect.InvocationTargetException
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:597)
com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:441)
com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:280)

……
root cause
java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I
org.hibernate.hql.ast.HqlSqlWalker.generateNamedParameter(HqlSqlWalker.java:915)
org.hibernate.hql.antlr.HqlSqlBaseWalker.parameter(HqlSqlBaseWalker.java:4764)
org.hibernate.hql.antlr.HqlSqlBaseWalker.expr(HqlSqlBaseWalker.java:1373)
org.hibernate.hql.antlr.HqlSqlBaseWalker.exprOrSubquery(HqlSqlBaseWalker.java:4243)
org.hibernate.hql.antlr.HqlSqlBaseWalker.comparisonExpr(HqlSqlBaseWalker.java:3725)
org.hibernate.hql.antlr.HqlSqlBaseWalker.logicalExpr(HqlSqlBaseWalker.java:1864)
org.hibernate.hql.antlr.HqlSqlBaseWalker.whereClause(HqlSqlBaseWalker.java:818)
展开
 我来答
Ice_Iolly
2014-10-17 · TA获得超过298个赞
知道小有建树答主
回答量:238
采纳率:100%
帮助的人:140万
展开全部
你的hql查询语句没问题吧,应该是
"from Employee e where e.username = "+"username"+"and password="+"password";
set 方法是sql语句经常用的吧

另外查询也可以用
List<Employee> list = this.getHibernateTemplate().find(hql);//这种方法查询返回的list也行的
后面加return list;//相当于返回一个查询的list;你的打印只是测试用的吧,具体的方法应该是return list才对。
更多追问追答
追问
你说的第一种确实可以,但是像我这种?占位符的参数绑定方法也是有的啊,我还换着用了命名参数也查不到。

还有你说的第二种,this.不出来getHibernateTemplate()
追答
你没加jar包吧,导入jar包才行,this.getHibernateTemplate()
你的占位符格式不正确吧,我不太记得了,可能是后面的问号要连续,你这样不行吧,
应该是,from Employee e where e.username and e.password = ?,?";
你试试这个,不行我帮你找下源码看下另外要用query.setParameter
楼宏峻0ir4af
2014-10-17
知道答主
回答量:25
采纳率:0%
帮助的人:18.2万
展开全部
加参数是query.setParameter不是query.setString
追问
query.setParameter也试过不行
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式