欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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对象
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