我有两个表与多对多关联。
- 数据库片段:
负载
标识
名称
会话
标识
日期
sessionsloads
LoadId
SessionId
- Hibernate映射片段:
/* loads.hbm.xml */
<set name="sessions" table="sessionsloads" inverse="true">
<key column="LoadId" />
<many-to-many column="SessionId" class="Session" />
</set>
…
/* sessions.hbm.xml */
<set name="loads" table="sessionsloads">
<key column="SessionId" />
<many-to-many column="LoadId" class="Load" />
</set>
为了从关联表 sessionsloads 中删除一个条目,我执行以下代码:
Session session = sessionDao.getObject(sessionId);
Load load = loadDao.getObject(loadId);
load.getSessions().remove(session);
loadDao.saveObject(load);
但是,启动后,此代码不会改变任何内容。
删除关联的正确方法是什么?
答案 0 :(得分:15)
您需要更新Load
和Session
之间链接的两面:
Session session = sessionDao.getObject(sessionId);
Load load = loadDao.getObject(loadId);
load.getSessions().remove(session);
session.getLoads().remove(load);
loadDao.saveObject(load);
实际上,许多开发人员使用防御性方法来管理双向关联。例如,在Load
上,您可以添加以下方法:
public void removeFromSessions(Session session) {
this.getSessions().remove(session);
session.getLoads().remove(this);
}
public void addToSessions(Session session) {
this.getSessions().add(session);
session.getLoads().add(this);
}
答案 1 :(得分:5)
看起来你只需要打开传递持久性(例如,cascade = all-delete-orphan为“完全”传递。)
- 编辑 谢谢你的upvote,虽然Pascal是准确的,单独的级联不足以解决原来的问题,但关系的双方都没有得到管理。教我匆匆回答:)
-
此外,一个名为Session的实体打破了我的大脑:(