我有三个实体:A
,B
和C
,它们之间的关系如下:
class A{
@ManyToMany
List<B> bs;
//other attributes and getter setters
}
class B{
@ManyToMany
List<C> cs;
//other attributes and getter setters
}
class C{
//other attributes and getter setters
}
但是从我当前的实体类中,我可以使用@JoinTable
在任意两个表之间建立关系。但我想要的是在一个单独的表中保存所有3个实体之间的关系,将这些实体的主键作为列。 (外键)
如果我们假设实体B
和C
已经保存(插入)到数据库中,我插入A
的新实体,如下所示:
A:{
"A_id": 1
B:[
"B_id": 1
{
C:[
{"C_id": 1}, {"C_id": 2}
]
},
{
"B_id": 2
C:[
{"C_id": 2}
]
}
]
}
然后A
应该保存在它的表中,关系应该列在一个单独的表中,如下所示:
A_id B_id C_id
=====================
1 1 1
1 1 2
1 2 2
我见过的一个相关问题here。但我认为我的情况不同,因为我在所有实体A
,B
和C
之间存在多对多的关系。
我不是要求完整的代码。只要它解决了目的,任何方法或确切参考都将是正确的。感谢
修改
我已经尝试实现答案中提到的单独关系表。但是这种方法的问题在于,当我从关系表中删除一行时,它还会从B
和C
的连接表中删除该条目。 (影响实体的先前关系B
和C
)
同样在更新行更新时,它会更改(执行插入)到实体B
和C
的连接表中。这不是预期的行为。我希望这个表只存储实体之间的关系,而不是改变这些实体之间的先前关系。
以下是我的新关系表:
@Entity
@Table(name = "relation_table")
public class RelationEntity {
@Id
@Column(name = "pk_relation_id")
@GeneratedValue(strategy = GenerationType.SEQUENCE)
private Integer relatoinId;
@OneToOne
@JoinColumn(name = "a_id")
private A a;
@OneToOne
@JoinColumn(name = "b_id")
private B b;
@OneToOne
@JoinColumn(name = "c_id")
private C c;
//getter and setters
}
答案 0 :(得分:6)
如果您想将relation
保留在单独的表格中,那么您只需执行以下操作即可保存primary keys
@Entity
@Table(name = "relation_bridge")
public class RelationBridge {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
@ManyToOne
@JoinColumn(name = "a")
private A a;
@ManyToOne
@JoinColumn(name = "b")
private B b;
@ManyToOne
@JoinColumn(name = "c")
private C c;
//getters & setters
}
修改强>
当我从关系表中删除一行时,它还会从
的先前关系B
和C
的连接表中删除条目&gt;。 (影响&gt;实体B
和C
)
除非明确定义,否则上述解决方案不应delete
parent
表中的条目。但是,您可能在其他类中使用其他映射,因此可以通过在映射中应用Cascading来控制此行为。
答案 1 :(得分:0)
那么使用你的新类RelationEntity和A nullable呢?当您打算删除&#34; new&#34;你更新它的关系将null放在一个属性中。这只是一个建议,请原谅,如果你不能这样做。