繁体   English   中英

使用Spring Data JPA中的Annotations连接两个以上的表

[英]Join more than two tables using Annotations in Spring Data JPA

我有三个实体: ABC ,它们之间的关系如下:

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在任何2个表之间建立关系。 但我想要的是在一个单独的表中保存所有3个实体之间的关系,将这些实体的主键作为列。 (外键)

如果我们假设实体BC已经保存(插入)到数据库中,我插入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

我在这里看到的一个相关问题。 但我认为我的情况不同,因为我在所有实体ABC之间存在多对多的关系。

我不是要求完整的代码。 只要它解决了目的,任何方法或确切参考都将是正确的。 谢谢

编辑:

我已经尝试实现答案中提到的单独关系表。 但是这种方法的问题在于,当我从关系表中删除一行时,它还会从BC的连接表中删除该条目。 (影响实体BC的先前关系)

此外,在更新更新行时,它会更改(执行插入)到实体BC的连接表中。 这不是预期的行为。 我希望这个表只存储实体之间的关系,而不是改变这些实体之间的先前关系。

以下是我的新关系表:

@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
}

如果你想将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
}

编辑

当我从关系表中删除一行时,它还从BC的连接表中删除了条目>。 (影响>实体BC的先前关系)

除非明确定义,否则上述解决方案不应delete parent表中的条目。 但是,您可能在其他类中使用其他映射,因此可以通过在映射中应用Cascading来控制此行为。

JPA和Hibernate级联类型的初学者指南

适合初学者的好读物

那么使用你的新类RelationEntity与A nullable。 当您打算删除“新”关系时,您更新它将null放在A属性中。 这只是一个建议,原谅如果你不能这样做。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM