qianlei0007 2008-09-10 10:22
浏览 205
已采纳

hibernate3 的多对一的外键更新问题!

[code="ruby"]
public class SysModel extends BaseEntity {

@ManyToOne(cascade = { CascadeType.MERGE })
@JoinColumn(name = "PARENT_ID")
private SysModel sysModel;

.......

}

[/code]
映射文件大概如此, 有一个自关联字段。

在操作的时候,遇到一个问题,当此字段为 null 的时候,我可以保存,但是不能更新,报错:

Hibernate: update SYS_MODEL set DELETE_FLAG=?, MODEL_NAME=?, ORDER_ID=?, remark=?, PARENT_ID=?, url=?, version=? where id=?
2008-09-10 09:55:31,906 ERROR [org.hibernate.event.def.AbstractFlushingEventListener] -
org.hibernate.TransientObjectException: object references an unsaved transient instance - save the transient instance before flushing: com.sctt.system.sys.model.bean.SysModel
at org.hibernate.engine.ForeignKeys.getEntityIdentifierIfNotUnsaved(ForeignKeys.java:219)
at org.hibernate.type.EntityType.getIdentifier(EntityType.java:397)
at org.hibernate.type.ManyToOneType.nullSafeSet(ManyToOneType.java:78)

也就是说,PARENT_ID=? 为 NULL 。我基本知道错误原因。
但是,我的本条数据,确实 没有外键呀, sysModel = null;
如何才能更新 这样的数据呢?往高人回答。

  • 写回答

1条回答

  • catstiger 2008-09-10 10:50
    关注

    同样的操作经常用到,比如部门管理,没有发现这个问题。
    应该与PARENT_ID=NULL没有关系。你可以试试:
    1.把当前的实体从父实体中移除:parent.getChildren().remove(child);
    2.update之前清空session缓存,session.clear()
    应该可以解决问题.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料