Ebean - 包含外键的复合主键

时间:2012-11-16 15:57:58

标签: playframework-2.0 ebean

我正在使用playframework(2.0.4)和Ebean ORM的最新版本。 这是我的简化数据库模式

TABLENAME (FIELD_NAME (, ...) )
User (id)
Group (id)
UserGroup (user_id, group_id, is_active)

我想创建我的实体模型,如下所示:

@Entity
public class UserGroup extends Model {
    private static final long serialVersionUID = 1L;

    @EmbeddedId
    public UserGroupPK pk;
    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "user_id", insertable = false, updatable = false)
    public User user;

    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "group_id", insertable = false, updatable = false)
    public Group group;
}

@Embeddable
public class UserGroupPK implements Serializable{
    private static final long serialVersionUID = 1L;

    public Long userId;
    public Long groupId;

    public UserGroupPK(Long userId, Long groupId) {
        this.userId = userId;
        this.groupId = groupId;
    }

    @Override
    public boolean equals(Object obj) {
        if (obj == null) {
            return false;
        }
        if (getClass() != obj.getClass()) {
            return false;
        }
        final UserGroupPK other = (UserGroupPK) obj;
        if ((this.userId == null) ? (other.userId != null) : !this.userId.equals(other.userId)) {
                return false;
            }
        if ((this.groupId == null) ? (other.groupId != null) : !this.groupId.equals(other.groupId)) {
            return false;
        }
        return true;
    }

    @Override
    public int hashCode() {
        int hash = 3;
        hash = 89 * hash + (this.userId != null ? this.userId.hashCode() : 0);
        hash = 89 * hash + (this.groupId != null ? this.groupId.hashCode() : 0);
        return hash;
    }
}

适合你。如果这个中间表没问题,那么用户和组实体呢?提前谢谢。

1 个答案:

答案 0 :(得分:4)

有些注释似乎不对,但无论如何都可行。

如果我是你,我会这样做:

@Embeddable
public class UserGroupPK implements Serializable{
    private static final long serialVersionUID = 1L;

    @Column(name = "user_id")
    public Long userId;
    @Column(name = "group_id")
    public Long groupId;

对于ManyToOne列:

@ManyToOne
@JoinColumn(name = "user_id", referenceColumnName = "id", nullable = false) // insertable and updatable by default are true, which I think are correct here
public User user;

// same for group

在您的用户实体中,您需要以下内容:

@OneToMany(mappedBy = "user", cascade = CascadeType.ALL)
public Set<UserGroup> groups

当你找到时,它就像

// find all users within a certain group
Ebean.find(User.class)
     .fetch("groups")
     .where().eq("groups.groupId", "...").findList();