我是eclipselink的新手,并尝试在manyTomany关联表中添加额外的列。
所以我决定使用两个@OneToMany和@ManyToOne来取代@ManyToMany关系。
我在以下链接中尝试过hibernate方式,但它不起作用。 http://www.mkyong.com/hibernate/hibernate-many-to-many-example-join-table-extra-column-annotation/
有没有人知道如何在eclispelink中构建它?
由于
-------------------------只需按照上面的链接粘贴测试代码------------- -
SIDEA:
@Entity
@Table(name = "SideA")
public class SideA {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private long id;
private List<ABAssociation> association = new ArrayList<ABAssociation>();
@OneToMany(fetch = FetchType.LAZY, mappedBy = "pk.sideA", cascade=CascadeType.ALL)
public List<ABAssociation> getAssociation() {
return this.association;
}
public void setAssociation(List<ABAssociation> association) {
this.association = association;
}
}
SideB:
@Entity
@Table(name = "SideB")
public class SideB {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private long id;
private List<ABAssociation> association = new ArrayList<ABAssociation>();
@OneToMany(fetch = FetchType.LAZY, mappedBy = "pk.sideB", cascade=CascadeType.ALL)
public List<ABAssociation> getAssociation() {
return this.association;
}
public void setAssociation(List<ABAssociation> association) {
this.association = association;
}
}
Associtation:
@Entity
@Table(name = "ABAssociation")
@AssociationOverrides({
@AssociationOverride(name = "pk.sideA",
joinColumns = @JoinColumn(name = "SIDEA_ID")),
@AssociationOverride(name = "pk.sideB",
joinColumns = @JoinColumn(name = "SIDEB_ID")) })
public class ABAssociation {
private ABAssociationPK pk = new ABAssociationPK();
@EmbeddedId
public ABAssociationPK getPk() {
return pk;
}
public void setPk(ABAssociationPK pk) {
this.pk = pk;
}
@Transient
public SideA getSideA() {
return getPk().getSideA();
}
public void setSideA(SideA sideA) {
getPk().setSideA(sideA);
}
@Transient
public SideB getSideB() {
return getPk().getSideB();
}
public void setSideB(SideB sideB) {
getPk().setSideB(sideB);
}
private String extracolumn;
}
ABAssociationPK:
@Embeddable
public class ABAssociationPK implements java.io.Serializable{
private static final long serialVersionUID = -3797694126054440157L;
private SideA sideA;
private SideB sideB;
public ABAssociationPK(){}
@ManyToOne
public SideA getSideA() {
return sideA;
}
public void setSideA(SideA sideA) {
this.sideA = sideA;
}
@ManyToOne
public SideB getSideB() {
return sideB;
}
public void setSideB(SideB sideB) {
this.sideB = sideB;
}
}
例外是:Exception Description: Predeployment of PersistenceUnit [testPU] failed.
Internal Exception: Exception [EclipseLink-7298] (Eclipse Persistence Services - 2.3.2.v20111125-r10461): org.eclipse.persistence.exceptions.ValidationException
Exception Description: The mapping [sideA] from the embedded ID class [class com.fuhu.nabisync.resource.model.entity.ABAssociationPK] is an invalid mapping for this class. An embeddable class that is used with an embedded ID specification (attribute [pk] from the source [class com.fuhu.nabisync.resource.model.entity.ABAssociation]) can only contain basic mappings. Either remove the non basic mapping or change the embedded ID specification on the source to be embedded.
答案 0 :(得分:3)
信息很清楚:
与嵌入式ID规范一起使用的可嵌入类可以 只包含基本映射。
因此,您不能在ABAssociationPK类中拥有ManyToOne关联。
标准的JPA方法是使用@MapsId
annotation。 javadoc提供了一个有用的示例。在您的特定情况下,ABAssociationPK
类应包含两个类型为long
的字段:aId
和bId
,映射为基本列。
Association
实体应包含关联,并使用@MapsId
注释:
@ManyToOne
@MapsId("aId")
public SideA getSideA() {
return sideA;
}
@ManyToOne
@MapsId("bId")
public SideB getSideB() {
return sideB;
}