`
zhangyou1010
  • 浏览: 299186 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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这个对象,可以更新成功。

同样的问题:http://zhang-zling.iteye.com/blog/432396
0
0
分享到:
评论
1 楼 wp0615032 2013-08-21  
因为那个timestamp是一个乐观锁,每次更新时这个填要带上

相关推荐

Global site tag (gtag.js) - Google Analytics