具有2个主键字段的JPA表
我有一个仅包含2个字段的表。该表具有由这两个字段形成的复合PK。
使用Netbeans从数据库创建实体bean时,不会像其他具有两个以上字段的表那样自动创建实体bean。
所以我想我需要自己创建实体bean。创建此实体bean的最佳实践是什么?是否必须包含COMPOSITE KEY
对象?
回答:
我不使用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;
}
- 使用PK字段定义一个未映射的POJO并像
@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()
}
}
在此示例ClassABId
中,为方便起见,使用了一个静态内部类。
Pascal
Thivent对以下问题的出色回答也解释了这些选项:如何使用Hibernate映射组合键?。
这个相关问题讨论了这些方法之间的差异:我应该使用哪种注释:@IdClass或@EmbeddedId。注意,该@IdClass
方法重复了字段的声明。
无论如何,我认为创建两个类没有其他选择。这就是为什么我问这个问题:映射仅包含复合PK而没有@IdClass或@EmbeddedId的类。似乎有一个特定于休眠的功能。
附带说明一下,如果您可以控制数据库结构,则还可以考虑避免使用复合键。这样做有一些原因。
以上是 具有2个主键字段的JPA表 的全部内容, 来源链接: utcz.com/qa/419317.html