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) 展开
但是有参数就会报错
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) 展开
展开全部
你的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才对。
"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
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询