当前位置: 代码迷 >> J2EE >> 用getHibernateTemplate步骤查询数据报错 java.lang.NoSuchFieldError: MANUAL
  详细解决方案

用getHibernateTemplate步骤查询数据报错 java.lang.NoSuchFieldError: MANUAL

热度:399   发布时间:2016-04-17 23:41:37.0
用getHibernateTemplate方法查询数据报错 java.lang.NoSuchFieldError: MANUAL
以前都是用openSession或者getCurrentSession的方法操作数据库,今天了解到有这种方法,试验了下,但报错了

public class BaseDaoHibernateImp extends HibernateDaoSupport{ 
protected List getList(final String hql){
return this.getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session session)
throws HibernateExceptionSQLException {
Query query = session.createQuery(hql);
List list = query.list();
return list;
}

});
//return this.getHibernateTemplate().find(hql);
}
}

BaseDaoHibernateImp.java这个类里面也没有写其他的方法了。
然后

public class StudentDaoImp extends BaseDaoHibernateImp implements StudentDao{
@SuppressWarnings("unchecked")
public List<Student> findAll() {
List<Student> students = new ArrayList<Student>();
final String hql = "from Student";
students = this.getList(hql);
return students;
}
}

然后运行报错
java.lang.NoSuchFieldError: MANUAL
at org.springframework.orm.hibernate3.SessionFactoryUtils.doGetSession(SessionFactoryUtils.java:333)
at org.springframework.orm.hibernate3.SessionFactoryUtils.getSession(SessionFactoryUtils.java:233)
at org.springframework.orm.hibernate3.HibernateTemplate.getSession(HibernateTemplate.java:457)
at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:393)
at org.springframework.orm.hibernate3.HibernateTemplate.executeFind(HibernateTemplate.java:343)
at com.xiaohao.hibernate.BaseDaoHibernateImp.getList(BaseDaoHibernateImp.java:15)
at com.xiaohao.dao.imp.StudentDaoImp.findAll(StudentDaoImp.java:35)
at com.xiaohao.service.imp.StudentServiceImp.getAll(StudentServiceImp.java:16)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:307)
at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:108)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:89)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202)
at $Proxy63.getAll(Unknown Source)
at com.xiaohao.action.StuNameAction.select(StuNameAction.java:40)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:270)
at org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:187)
at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:431)
at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236)
at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196)
at org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:414)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:619)
我在想 是不是 什么地方少配置了什么?或者少写了什么地方?我试了下 用 原来经常用的sessionFactory.openSession()这个方法能成功查询出结果来。但是为什么这个不行呢?
求解答。
------解决思路----------------------
hibernate jar版本的问题吧
  相关解决方案