如何在hibernate中映射用户,部门,角色?

时间:2017-08-05 05:15:57

标签: java hibernate hibernate-mapping hibernate-annotations

我在我的网络应用程序中使用了hibernate 4。我有人,部门和角色。正如名字一个人可以拥有的不仅仅是角色,还有一个以上的部门。但每个角色都特定于特定部门。我的设计如下。

Person.java

@Entity
@Data
public class Person implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column
    private int id;

    @Column
    private String name;

    @JoinTable(name = "person_department_role",
            joinColumns = @JoinColumn(name = "person_id"),
            inverseJoinColumns = @JoinColumn(name = "role_id"))
    @MapKeyJoinColumn(name = "department_id")
    @ElementCollection
    private Map<Department, Role> roleByDepartment = new HashMap<>();
}

Department.java

@Entity
@Data
public class Department implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column
    private int id;

    @Column
    private String name;

}

Role.java

@Entity
@Data
public class Role implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column
    private int id;

    @Column
    private String name;

}

根据上述设置,我不能为任何人添加多个部门。需要对此代码进行哪些更改,以便一个人可以拥有多个角色以及多个部门?任何建议。

1 个答案:

答案 0 :(得分:0)

您需要正确指定@OneToMany@ManyToOne关系。

此外,如果您希望使用PersonDepartments检索Roles,反之亦然,则需要指定杰克逊@JsonManagedReference和{{1也注释。

如果您仍然遇到问题,请查看以下示例并在此处再次发布。

OneToMany / ManyToOne: http://fruzenshtein.com/bidirectional-many-to-one-association/

JsonManagedReference / JsonBackReference: http://www.baeldung.com/jackson-bidirectional-relationships-and-infinite-recursion