现在的位置: 首页 > 综合 > 正文

Hibernat使用中遇到的org.hibernate.exception.GenericJDBCException异常

2013年09月15日 ⁄ 综合 ⁄ 共 2128字 ⁄ 字号 评论关闭

在我做的项目中,保存一个对象(提交表单时),出现了这个异常。并且提示出:

Could not execute JDBC batch update

详细信息如下:

  1. HTTP Status 500 - 
  2. --------------------------------------------------------------------------------
  3. type Exception report
  4. message 
  5. description The server encountered an internal error () that prevented it from fulfilling this request.
  6. exception 
  7. org.hibernate.exception.GenericJDBCException: Could not execute JDBC batch update
  8.     org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:103)
  9.     org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:91)
  10.     org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
  11.     org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:202)
  12.     org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:235)
  13.     org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:140)
  14.     org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:297)
  15.     org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:27)
  16.     org.hibernate.impl.SessionImpl.flush(SessionImpl.java:985)
  17.     org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:333)
  18.     org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
  19.     org.qpyong.emp.dao.WorkersInfoDAO.merge(WorkersInfoDAO.java:191)
  20.     org.qpyong.emp.servlet.EmployeeServlet.actionForUpdate(EmployeeServlet.java:323)
  21.     org.qpyong.emp.servlet.EmployeeServlet.doPost(EmployeeServlet.java:56)
  22.     javax.servlet.http.HttpServlet.service(HttpServlet.java:709)
  23.     javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
  24.     org.qpyong.emp.util.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:40)
  25.     org.qpyong.emp.util.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:40)
  26. note The full stack trace of the root cause is available in the Apache Tomcat/5.0.28 logs.
  27. 注意到以上代码中 红色粗体没有?刚开始我怎么也找不到原因。然后在之后的不段测试中,无意间解决了问题。
  28. 即:发生这个错误的很可能的原因就是:这个对象对应的表的某个(些)字段的长度不够。
  29. 比如我原来的数据库中的 workdate  字段是 DATE 类型,长度是8。后来我把其类型改为VARCHAR,但我却忘了把其长度改了过来,因为在页面中我使用的是日历控件,所以长度为11位。所以就抛出了这个异常。
【上篇】
【下篇】

抱歉!评论已关闭.