JPA表有2个主键字段

use*_*810 11 java orm jpa composite-key jpa-2.0

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

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

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

Xav*_*ica 29

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

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

  • @Embeddable使用PK字段定义单独的对象,并@EmbeddedId@Entity类中使用它

    @Embeddable
    public class MyCompositePK { 
        @Column
        private String fieldA;
        @Column
        private String fieldB;
    }
    @Entity 
    public class MyBean { 
        @EmbeddedId
        private MyCompositePK id;
        @Column
        private String fieldC;
    }
    
    Run Code Online (Sandbox Code Playgroud)
  • 限定非映射POJO与PK字段,并用它作为@IdClass@Entity.

    @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()
        }
    }
    
    Run Code Online (Sandbox Code Playgroud)

    在这个例子中ClassABId是一个静态内部类,只是为了方便.

这些选项也在Pascal Thivent对这个问题的出色答案中进行了解释:如何使用Hibernate映射复合键?.

这个相关问题讨论了这些方法之间的差异:我应该使用哪种anotation:@IdClass或@EmbeddedId.请注意,字段的声明与@IdClass方法重复.

无论如何,我认为没有其他方法可以创建两个类.这就是我问这个问题的原因:映射一个只包含没有@IdClass或@EmbeddedId的复合PK的类.似乎有一个特定于休眠的功能.

另外,如果您可以控制数据库结构,也可以考虑避免使用复合键.有一些理由这样做.

  • 鉴于该对象只包含两个主键字段,它可以是它自己的`IdClass`吗? (2认同)