编程语言
首页 > 编程语言> > java – 包含2个主键字段的JPA表

java – 包含2个主键字段的JPA表

作者:互联网

我有一个只包含2个字段的表.该表具有由这两个字段形成的复合PK.

使用Netbeans从数据库创建实体bean时,实体bean不会像其他具有2个以上字段的表一样自动创建.

所以我想我需要自己创建实体bean.创建此实体bean的最佳做法是什么?是否必须包含COMPOSITE KEY对象?

解决方法:

我不使用NetBeans,因此我无法真正说出它的映射工具.

对于映射复合键,有几个选项.您可以

>使用PK字段定义单独的@Embeddable对象,并在@Entity类中将其用作@EmbeddedId

@Embeddable
public class MyCompositePK { 
    @Column
    private String fieldA;
    @Column
    private String fieldB;
}
@Entity 
public class MyBean { 
    @EmbeddedId
    private MyCompositePK id;
    @Column
    private String fieldC;
}

>使用PK字段定义未映射的POJO,并在@Entity中将其用作@IdClass.

@Entity
@IdClass(value=ClassAB.ClassABId.class)
public class ClassAB implements Serializable {
    private String idA;
    private String idB;

    @Id
    @Column(name="ID_A")
    public String getIdA(){ return idA; }
    public void setIdA(String idA){ this.idA = idA; }

    @Id
    @Column(name="ID_B")
    public String getIdB(){ return idB; }
    public void setIdB(String idB){ this.idB = idB; }

    static class ClassABId implements Serializable {
        private String idA;
        private String idB;

        public String getIdA(){ return idA; }
        public void setIdA(String idA){ this.idA = idA; }

        public String getIdB(){ return idB; }
        public void setIdB(String idB){ this.idB = idB; }

        // implement equals(), hashcode()
    }
}

在此示例中,ClassABId是一个静态内部类,只是为了方便起见.

这些选项也在Pascal Thivent对这个问题的出色答案中进行了解释:How to map a composite key with Hibernate?.

这个相关的问题讨论了这些方法之间的差异:Which anotation should I use: @IdClass or @EmbeddedId.请注意,字段的声明与@IdClass方法重复.

无论如何,我认为没有其他方法可以创建两个类.这就是我问这个问题的原因:Mapping a class that consists only of a composite PK without @IdClass or @EmbeddedId.看来这里有一个特定于hibernate的功能.

另外,如果您可以控制数据库结构,也可以考虑避免使用复合键. There are some reasons to do so.

标签:composite-key,java,orm,jpa,jpa-2-0
来源: https://codeday.me/bug/20191004/1852817.html