T1 と T2 の 2 つのテーブルがあります。T1 には id(PK)、name、type があります。T2 には SID、TID、タイプがあります。T2 のプライマリ キーは、SID、TID、タイプの 3 つすべての組み合わせです。現在、SID と TID は外部キーであり、T1 の ID にもマップされています。JPAでこれを作成する方法を誰かが助けてください。
package com.sap.table;
import java.io.Serializable;
import java.lang.String;
import javax.persistence.*;
import static javax.persistence.GenerationType.TABLE;
import static javax.persistence.GenerationType.IDENTITY;
/**
* Entity implementation class for Entity: Relations
*
*/
@IdClass(RelationsPK.class)
@Entity
@Table (name = "demo_relations11")
public class Relations implements Serializable {
//@EmbeddedId
//@JoinColumn(referencedColumnName="AssetID")
//private RelationsPK Relations_PK;
// @Id
//// @JoinColumn(referencedColumnName="AssetID")
// private String TargetID;
@Id
private String Type;
private static final long serialVersionUID = 1L;
// @MapsId("SourceID")
@Id
@ManyToOne(targetEntity=Asset.class)
@JoinColumns({
@JoinColumn(name="SourceID", referencedColumnName="AssetID"),
@JoinColumn(name="TargetID", referencedColumnName="AssetID")
})
//@JoinColumn(referencedColumnName="AssetID")
Asset asset;
public Asset getAsset() {
return asset;
}
public void setAsset(Asset asset) {
this.asset = asset;
}
public Relations() {
super();
}
// public String getSourceID() {
// return this.SourceID;
// }
//
// public void setSourceID(String SourceID) {
// this.SourceID = SourceID;
// }
// public String getTargetID() {
// return this.TargetID;
// }
//
// public void setTargetID(String TargetID) {
// this.TargetID = TargetID;
// }
public String getType() {
return this.Type;
}
public void setType(String Type) {
this.Type = Type;
}
}
T1 - ID(PK)、名前、タイプ T2 - SID (FK から ID)、TID (FK から ID)、タイプ T2 の PK - SID、TID、タイプ