首页 文章

JPA:具有复合主键的持久化实体

提问于
浏览
2

我在数据库A和B中有两个表 . 表B有一个由两个字段组成的id . 其中一个是A的外键.A的ID在序列插入时自动生成 .

A:
    ID (PK)
    (*other fields*)

B:
    SOME_FIELD (PK)
    A_ID (PK, FK to A)

我已经在JPA specification之后映射了JPA(Hibernate)中的两个表,这样:

@Entity
@Table(name = "A")
public class A implements Serializable {
    @Id
    @SequenceGenerator(name = "A_SEQ", sequenceName = "A_SEQ")
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "A_SEQ")
    @Column(name = "ID")
    private Long id;
  (...)
}

@Entity
@Table(name = "B")
public class B implements Serializable {
    @EmbeddedId
    @AttributeOverride(name = "someField", column = @Column(name = SOME_FIELD))
    private BPK pk;

    @MapsId("aId")
    @ManyToOne
    @JoinColumn(name = "A_ID")
    private A a;
  (...)
}

@Embeddable
public class BPK implements Serializable {
    private Long aId;
    private String someField;

    @Override
    public boolean equals(Object o) {
        (...)
    }

    @Override
    public boolean hashCode() {
        (...)
    }

    (...)
}

问题是,当我尝试保存调用entityManager.persist(b)的B对象时,其中b.a设置为A对象,该对象已存在于数据库中,我得到一个异常:

javax.persistence.PersistenceException: org.hibernate.PersistentObjectException: detached entity passed to persist: package.name.A

我不知道为什么会这样 . 我正在尝试保存B类的对象,而不是A.我的实体类错了吗?或者也许我不应该坚持这里?

1 回答

  • 3

    可能是实体A不再由实体经理持有 . 您是否尝试过使用A的“新鲜”实例设置B.a?

    b.setA(get(b.a));
    entityManager.persist(b);
    

    get(b.a) 方法可以是您通常用于从数据源中查找实体A的任何方法,例如 entityManager.getReference(A.class, a.id);

相关问题