初学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这个对象,可以更新成功。
同样的问题:[url]http://zhang-zling.iteye.com/blog/432396[/url]
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这个对象,可以更新成功。
同样的问题:[url]http://zhang-zling.iteye.com/blog/432396[/url]