0

ここに概説されているモデルに必要な変更を加えました。ただし、結合テーブル エンティティに何を配置すればよいかわかりません。

私の結合テーブルには代理キーと 2 つの追加の列 (date と varchar) があることに注意してください。

私がこれまでに持っているものは次のとおりです。

ユーザー.java

@Entity
@Table (name = "tbl_bo_gui_user")
@DynamicInsert
@DynamicUpdate
public class User implements Serializable {
    private String id;
    private String ntName;
    private String email; 
    private Set<GroupUser> groupUsers = new HashSet<GroupUser>(0);

    // Constructors and some getters setters omitted

    @OneToMany(fetch = FetchType.LAZY, mappedBy = "pk.user", cascade=CascadeType.ALL)
    public Set<GroupUser> getGroupUsers() {
        return groupUsers;
    }

    public void setGroupUsers(Set<GroupUser> groupUsers) {
        this.groupUsers = groupUsers;
    }
}

Group.java

@Entity
@Table (name = "tbl_bo_gui_group")
@DynamicInsert
@DynamicUpdate
public class Group implements Serializable {
    private String id;
    private String groupName;
    private String groupDesc;
    private Set<GroupUser> groupUsers = new HashSet<GroupUser>(0);

    // Constructors and some getters setters omitted

    @OneToMany(fetch = FetchType.LAZY, mappedBy = "pk.group", cascade=CascadeType.ALL)
    public Set<GroupUser> getGroupUsers() {
        return groupUsers;
    }

    public void setGroupUsers(Set<GroupUser> groupUsers) {
        this.groupUsers = groupUsers;
    }
}

問題は、結合テーブル エンティティに何を配置すればよいかわからないことです。ここにあります。

GroupUser.java

@Entity
@Table (name = "tbl_bo_gui_group_user")
@DynamicInsert
@DynamicUpdate
@AssociationOverrides({
    @AssociationOverride(name = "pk.user", 
            joinColumns = @JoinColumn(name = "id")),
    @AssociationOverride(name = "pk.group", 
            joinColumns = @JoinColumn(name = "id")) })
public class GroupUser implements Serializable {
    private String id;
    private User userId;
    private Group groupId;
    private Date dateCreated;
    private String createdBy;

    // constructors and getters and setters for each property

    // What now? ? No idea
}
4

1 に答える 1