hibernate异常 org.hibernate.StaleObjectStateException: Row was updated or deleted

初学hibernate,我是这样遇到这个异常的,首先用DAO查出一个对象,然后改变该对象的一些属性,再用这个DAO去save该对象,就出现了:
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]
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值