2017-08-05 87 views
1

我有一個5個實體,用戶,角色,權限的UserRole,PermisssionRoles,我將如何構建一個JPA類使用數據透視表enter image description here高級JPA與數據透視表

公共類角色實現Serializable {

獲取數據

// @OneToMany(mappedBy =「role_id」) // private Collection permissionRoleCollection;

@Id 
@GeneratedValue(strategy = GenerationType.IDENTITY) 
@Basic(optional = false) 
@Column(name = "id") 
private Integer id; 
@Size(max = 100) 
@Column(name = "name") 
private String name; 
@Size(max = 50) 
@Column(name = "code") 
private String code; 
@Size(max = 255) 
@Column(name = "brief") 
private String brief; 
@Size(max = 8) 
@Column(name = "status") 
private String status; 
@Basic(optional = false) 
@NotNull 
@Column(name = "date_created") 
@Temporal(TemporalType.TIMESTAMP) 
private Date dateCreated; 
@Column(name = "date_updated") 
@Temporal(TemporalType.TIMESTAMP) 
private Date dateUpdated; 

@JoinColumn(name = "created_by", referencedColumnName = "id") 
@ManyToOne 
private User createdBy; 
@JoinColumn(name = "updated_by", referencedColumnName = "id") 
@ManyToOne 
private User updatedBy; 

@ManyToOne 
@JoinTable(name = "permission_role", 
     joinColumns = @JoinColumn(name = "userid", 
       referencedColumnName = "userid"), 
     inverseJoinColumns = @JoinColumn(name = "groupid", 
       referencedColumnName = "groupid") 
) 
private Collection<PermissionRole> permissionRoles; 

public Roles() { 
} 

public Roles(Integer id) { 
    this.id = id; 
} 

public Roles(Integer id, Date dateCreated) { 
    this.id = id; 
    this.dateCreated = dateCreated; 
} 

public Integer getId() { 
    return id; 
} 

public void setId(Integer id) { 
    this.id = id; 
} 

public String getName() { 
    return name; 
} 

public void setName(String name) { 
    this.name = name; 
} 

public String getCode() { 
    return code; 
} 

public void setCode(String code) { 
    this.code = code; 
} 

public String getBrief() { 
    return brief; 
} 

public void setBrief(String brief) { 
    this.brief = brief; 
} 

public String getStatus() { 
    return status; 
} 

public void setStatus(String status) { 
    this.status = status; 
} 

public Date getDateCreated() { 
    return dateCreated; 
} 

public void setDateCreated(Date dateCreated) { 
    this.dateCreated = dateCreated; 
} 

public Date getDateUpdated() { 
    return dateUpdated; 
} 

public void setDateUpdated(Date dateUpdated) { 
    this.dateUpdated = dateUpdated; 
} 


public User getCreatedBy() { 
    return createdBy; 
} 

public void setCreatedBy(User createdBy) { 
    this.createdBy = createdBy; 
} 

public User getUpdatedBy() { 
    return updatedBy; 
} 

public void setUpdatedBy(User updatedBy) { 
    this.updatedBy = updatedBy; 
} 


@Override 
public int hashCode() { 
    int hash = 0; 
    hash += (id != null ? id.hashCode() : 0); 
    return hash; 
} 

@Override 
public boolean equals(Object object) { 
    // TODO: Warning - this method won't work in the case the id fields are not set 
    if (!(object instanceof Roles)) { 
     return false; 
    } 
    Roles other = (Roles) object; 
    return !((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))); 
} 

@Override 
public String toString() { 
    return "myproperty.v1.db._entities.Roles[ id=" + id + " ]"; 
} 

}

回答

0

我想你想有許多用戶和角色之間,也作用和權限之間的關係很多。如果你會宣佈@ManyToMany註釋,hibernate會知道要創建一箇中間表...

Check this

而且你可以以編程方式創建「內部」表和用戶註釋@OneToMany到內部和@OneToMany從角色到內在,並與特權相同

+0

這對我工作感謝 –