原创 关于Hibernate的 Batch update returned unexpected row count from update异常收藏

新一篇: 关于页面执行效率的问题 | 旧一篇: 为即将到来的30岁留下一点印记

ERROR [http-8080-Processor22] (BatchingBatcher.java:60) - Exception executing batch:
org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual row count: 0 expected: 1
 查了很多资料,没有人能说清楚这个异常是如何产生的。

在Hibernate映射一对多,多对一,多对多的时候新增常常会出现这个异常,代码如下:

public void saveFunctionCell(FunctionCell functionCell, Integer pid) {
  System.out.println("现在进行新增操作");
  FunctionCell fc = new FunctionCell();
    try {
   BeanUtils.copyProperties(fc, functionCell);
  } catch (IllegalAccessException e) {
   e.printStackTrace();
  } catch (InvocationTargetException e) {
   e.printStackTrace();
  }
  fc.setFuncCellID(null);
  // 获得父权限
  FunctionCell pfc = functionCellDao.findFunctionCellByID(pid);
  fc.setParentFunctionCell(pfc);
  functionCellDao.saveFunctionCell(fc);
 }

注意特别标识出来的这个地方,BeanUtils拷贝Bean属性的时候,它会将你的Integer类型全部设置成0,在这里设置一个空,这样就不会抛出错误了。


发表于 @ 2007年06月18日 16:05:00|评论(loading...)|编辑

新一篇: 关于页面执行效率的问题 | 旧一篇: 为即将到来的30岁留下一点印记

评论

#javaex 发表于2007-10-07 13:30:00  IP: 218.19.44.*
呢个问题, 加多个set个id就可解决.
因为之前我也碰到呢类问题,搞左我成半日.

if(!fname.equals(name)){ //fname, fpwd, fid从数据库中找的
t.setTeacherid(fid);
t.setName(name);
t.setPassword(fpwd);
teacherService.update(t);
}else if(!fpwd.equals(pwd)){
t.setTeacherid(fid);
t.setPassword(pwd);
t.setName(fname);
teacherService.update(t);
}

javaex@163.com
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © DarkXie