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