hibernate异常 org.hibernate.StaleObjectStateException: Row was updated or deleted
程序员文章站
2022-01-18 10:03:54
...
初学hibernate,我是这样遇到这个异常的,首先用DAO查出一个对象,然后改变该对象的一些属性,再用这个DAO去save该对象,就出现了:
Row was updated or deleted by another transaction (or unsaved-value mapping was incorrect):
我开始以为如果一个对象是持久的对象,就不能再去save了,因为DB里面已经有同样主键的记录了,实际上不是这样子的,到网上也查了一下这个异常,感觉还是不是很理解。
我写了个小例子测试了下:
bean对象
对应的配置文件
把datetime字段配置为时间戳。
我发现如果我用DAO去查数据时,如果数据库中对应记录的datetime字段为null,我把该记录用DAO查出来,再改变一些属性的值,再save的话,就会出现这个异常。
但是如果该记录的datetime字段的值不为null的时候,再save这个对象,可以更新成功。
同样的问题:http://zhang-zling.iteye.com/blog/432396
Row was updated or deleted by another transaction (or unsaved-value mapping was incorrect):
我开始以为如果一个对象是持久的对象,就不能再去save了,因为DB里面已经有同样主键的记录了,实际上不是这样子的,到网上也查了一下这个异常,感觉还是不是很理解。
我写了个小例子测试了下:
bean对象
public class Post { // 编号 private long id; // 上级ID,对于发言,此ID为0,对于回复则指向发言的ID private long idParent; // 发言的用户 private User user; // 标题 private String title; // 内容 private String content; // 发言时间 private Date datetime; //该主题的所有回复 private Set<Post> replyPost = new HashSet<Post>();
对应的配置文件
<id name="id" type="long"> <column name="Id" /> <generator class="native" /> </id> <timestamp name="datetime" column="datetime"/> <property name="title" type="string"> <column name="title" /> </property> <property name="content" type="string"> <column name="content"/> </property> <many-to-one name="user" column="userid" class="net.java2000.notepad.User" cascade="save-update"/> <property name="idParent"> <column name="idparent"/> </property> <set name="replyPost" table="t_post" lazy="false" inverse="true"> <key> <column name="idparent"></column> </key> <one-to-many class="net.java2000.notepad.Post"/> </set>
把datetime字段配置为时间戳。
我发现如果我用DAO去查数据时,如果数据库中对应记录的datetime字段为null,我把该记录用DAO查出来,再改变一些属性的值,再save的话,就会出现这个异常。
但是如果该记录的datetime字段的值不为null的时候,再save这个对象,可以更新成功。
同样的问题:http://zhang-zling.iteye.com/blog/432396