Row was updated or deleted by another transaction 异常原因及处理

来源:互联网 发布:军团要塞知乎 编辑:程序博客网 时间:2024/05/21 10:10
org.hibernate.StaleObjectStateException:
Row was updated or deleted by another transaction (or unsaved-value mapping was incorrect): [com.xx.xx:11]

说明操作的对象时应用了乐观锁机制,或定义pojo时定义了version字段.

错误原因:

当在进行操作时,当前version版本与数据库中version版本不一致;

             1:两个以上的session同时对此记录进行了相似操作;
             2:数据提交问题:
                   例如通过编辑页面来修改一条记录时:提交上来的form值对象中version为空或者大于数据库中对应该记录的version字段值,当update时,version不一致就会出错;

解决:     

1.用form提交数据时,把version也一并提交上来;

2.从数据库中把version查出来,赋给实体对象;再更新;
0 0
原创粉丝点击