hibernate 一对一双向关联 无法保存

大侠们,小弟今天在项目中遇到一个问题。

就是双向关联保存的时候老报这个版本号不对错误:

 

2012-10-18 17:15:20,234 ERROR [org.hibernate.event.def.AbstractFlushingEventListener] - Could not synchronize database state with session
 org.hibernate.StaleObjectStateException: Row was updated or deleted by another transaction (or unsaved-value mapping was incorrect): [com.jinying.entity.user.Seller#4c816ca7cdaf4ab386de38b706cde64e]
 

 

关联关系:

 

       <one-to-one name="seller" class="com.jinying.entity.user.Seller" cascade="all" property-ref="user" ></one-to-one> 

 

 

    <many-to-one name="user" update="false" insert="false" cascade="save-update" class="com.jinying.entity.user.User" column="usid" unique="true" /> 
 

 

 

   user.setSeller(seller);
           seller.setUser(user);
           UserService userService = (UserService) ctx.getBean("userService");
           userService.save(user);

 

但是执行的时候并不是2个insert而是先insert user再update更新seller,如下:

 

Hibernate: insert into b_users (VerID, IsDel, username, password, CreateUserID, CreateUser, CreateDate, iD) values (?, ?, ?, ?, ?, ?, ?, ?)
Hibernate: update b_sellers set VerID=?, IsDel=?, username=?, realname=?, sex=?, email=?, age=?, addr=?, postcode=?, phone=?, mobile=?, comp=?, ismain=?, idcard=?, idcardurl=?, ischeck=?, CheckUserID=?, CheckUser=?, CheckDate=?, CreateUserID=?, CreateUser=?, CreateDate=?, ModifyUserID=?, ModifyUser=?, ModifyDate=?, PermitUserID=?, PermitUser=?, PermitDate=?, wangwang=?, companyid=?, submitApply=? where iD=? and VerID=?

 

不知道这到底是为什么,请大侠们帮忙下,谢谢。

 

4个回答

Could not synchronize database state with session

org.hibernate.StaleObjectStateException Row was updated or deleted by another transaction (or unsaved-value mapping was incorrect): [com.jinying.entity.user.Seller#4c816ca7cdaf4ab386de38b706cde64e]

seller 是不是之前保存过? 此处很可能是VerID=? 乐观锁问题造成的(先把锁版本查出来)

caonima008
caonima008 我自己写了个测试的例子,如果保存seller是可以的,反过来不行,然后把cascade设成all暂时解决了,两个保存都可以。明天继续跟踪。不知道到底是啥问题。。难道是我学艺不精。哎。。多谢大师
7 年多之前 回复
jinnianshilongnian
jinnianshilongnian 1、many-to-one的cascade="save-update" 需要删掉 2、many-to-one 改成one-to-one试试
7 年多之前 回复
caonima008
caonima008 使用UUID生成之后set给他
7 年多之前 回复
jinnianshilongnian
jinnianshilongnian 如果是首次保存 seller主键如何生成的? http://jinnianshilongnian.iteye.com/blog/1522591
7 年多之前 回复
caonima008
caonima008 你好,很高兴你能回答,我确信是首次保存。
7 年多之前 回复

当企图更新一个不存在的id实体时,便发生了这样的异常。
一般是对象id没有的问题。

奇怪了,我用你的代码测试了一下,没有update语句啊,我把我的测试代码发给你看看情景有什么不同?

双向关联关系应该设定一个主控端,由主控端来维护两者之间的关系。

caonima008
caonima008 关键1对1 主控方不能设置,默认的吗?
7 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问