角色和权限Hibernate实体映射配置
2016-08-28 14:09
246 查看
角色实体
package cn.itcast.oa.domain;
import java.util.HashSet;
import java.util.Set;
/**
* 岗位
*
* @author tyg
*
*/
public class Role {
private Long id;
private String name;
private String description;
private Set<User> users = new HashSet<User>();
private Set<Privilege> privileges = new HashSet<Privilege>();
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Set<Privilege> getPrivileges() {
return privileges;
}
public void setPrivileges(Set<Privilege> privileges) {
this.privileges = privileges;
}
}
权限实体package cn.itcast.oa.domain;
import java.util.HashSet;
import java.util.Set;
/**
* 权限
*
* @author tyg
*
*/
public class Privilege {
private Long id;
private String url;
private String name; // 权限名称
private Set<Role> roles = new HashSet<Role>();
private Privilege parent; // 上级权限
private Set<Privilege> children = new HashSet<Privilege>(); // 下级权限
public Privilege() {
}
public Privilege(String name, String url, Privilege parent) {
this.name = name;
this.url = url;
this.parent = parent;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set<Role> getRoles() {
return roles;
}
public void setRoles(Set<Role> roles) {
this.roles = roles;
}
public Privilege getParent() {
return parent;
}
public void setParent(Privilege parent) {
this.parent = parent;
}
public Set<Privilege> getChildren() {
return children;
}
public void setChildren(Set<Privilege> children) {
this.children = children;
}
}
两者映射<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.itcast.oa.domain">
<class name="Role" table="itcast_role">
<id name="id">
<generator class="native"/>
</id>
<property name="name" />
<property name="description" />
<!-- users属性,本类与User的多对多 -->
<set name="users" table="itcast_user_role">
<key column="roleId"></key>
<many-to-many class="User" column="userId"></many-to-many>
</set>
<!-- privileges属性,本类与Privilege的多对多 -->
<set name="privileges" table="itcast_role_privilege" lazy="false">
<key column="roleId"></key>
<many-to-many class="Privilege" column="privilegeId"></many-to-many>
</set>
</class>
</hibernate-mapping>
Hibernate实体映射总结
<!-- users属性,本类与User的一对多 -->
格式:?属性,本类与?的?
?1 属性名
?2 关联对类型
?3 关系
多对一:
<many-to-one name="" class="" column=""></many-to-one>
一对多(Set):
<set name="">
<key column=""></key>
<one-to-many class=""/>
</set>
多对多(Set):
<set name="" table="">
<key column=""></key>
<many-to-many class="" column=""></many-to-many>
</set>
本文出自 “点滴积累” 博客,请务必保留此出处http://tianxingzhe.blog.51cto.com/3390077/1743577
package cn.itcast.oa.domain;
import java.util.HashSet;
import java.util.Set;
/**
* 岗位
*
* @author tyg
*
*/
public class Role {
private Long id;
private String name;
private String description;
private Set<User> users = new HashSet<User>();
private Set<Privilege> privileges = new HashSet<Privilege>();
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Set<Privilege> getPrivileges() {
return privileges;
}
public void setPrivileges(Set<Privilege> privileges) {
this.privileges = privileges;
}
}
权限实体package cn.itcast.oa.domain;
import java.util.HashSet;
import java.util.Set;
/**
* 权限
*
* @author tyg
*
*/
public class Privilege {
private Long id;
private String url;
private String name; // 权限名称
private Set<Role> roles = new HashSet<Role>();
private Privilege parent; // 上级权限
private Set<Privilege> children = new HashSet<Privilege>(); // 下级权限
public Privilege() {
}
public Privilege(String name, String url, Privilege parent) {
this.name = name;
this.url = url;
this.parent = parent;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set<Role> getRoles() {
return roles;
}
public void setRoles(Set<Role> roles) {
this.roles = roles;
}
public Privilege getParent() {
return parent;
}
public void setParent(Privilege parent) {
this.parent = parent;
}
public Set<Privilege> getChildren() {
return children;
}
public void setChildren(Set<Privilege> children) {
this.children = children;
}
}
两者映射<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.itcast.oa.domain">
<class name="Role" table="itcast_role">
<id name="id">
<generator class="native"/>
</id>
<property name="name" />
<property name="description" />
<!-- users属性,本类与User的多对多 -->
<set name="users" table="itcast_user_role">
<key column="roleId"></key>
<many-to-many class="User" column="userId"></many-to-many>
</set>
<!-- privileges属性,本类与Privilege的多对多 -->
<set name="privileges" table="itcast_role_privilege" lazy="false">
<key column="roleId"></key>
<many-to-many class="Privilege" column="privilegeId"></many-to-many>
</set>
</class>
</hibernate-mapping>
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="cn.itcast.oa.domain"> <class name="Privilege" table="itcast_privilege"> <id name="id"> <generator class="native"/> </id> <property name="url" /> <property name="name" /> <!-- roles属性,本类与Role的多对多--> <set name="roles" table="itcast_role_privilege"> <key column="privilegeId"></key> <many-to-many class="Role" column="roleId"></many-to-many> </set> <!-- parent属性,本类与Privilege(上级)的多对一--> <many-to-one name="parent" class="Privilege" column="parentId"></many-to-one> <!-- children属性,本类与Privilege(下级)的一对多--> <set name="children" lazy="false"> <key column="parentId"></key> <one-to-many class="Privilege"/> </set> </class> </hibernate-mapping>
Hibernate实体映射总结
<!-- users属性,本类与User的一对多 -->
格式:?属性,本类与?的?
?1 属性名
?2 关联对类型
?3 关系
多对一:
<many-to-one name="" class="" column=""></many-to-one>
一对多(Set):
<set name="">
<key column=""></key>
<one-to-many class=""/>
</set>
多对多(Set):
<set name="" table="">
<key column=""></key>
<many-to-many class="" column=""></many-to-many>
</set>
本文出自 “点滴积累” 博客,请务必保留此出处http://tianxingzhe.blog.51cto.com/3390077/1743577
相关文章推荐
- 角色和权限Hibernate实体映射配置
- javaEE 用户、部门、角色、权限实体的关系设计与hibernate映射配置文件关系总结
- ant深入浅出(一)ant+xdoclet 生成hibernate配置文件以及实体映射文件
- Hibernate实体映射配置1(java@注解方式)
- Hibernate实体关系关联映射中配置文件的编写
- ant深入浅出(一)ant+xdoclet 生成hibernate配置文件以及实体映射文件
- hibernate实体映射的一些可选优化/配置
- hibernate基本的配置-xml(实体映射)和简单使用
- Hibernate 实体映射 @注解与xml 配置方式比较
- hibernate实体配置关系映射&延迟加载
- hibernate实体映射配置:多对多、一对多、多对一、特殊的多对一
- Hibernate(二)结构-配置文件-实体映射及配置文件
- Hibernate实体映射配置1(java@注解方式)
- Hibernate实体映射配置(XML)简单三步完美配置
- hibernate5实体映射注解配置注解全面解析
- hibernate 注解方式配置实体的映射
- Hibernate基于注解方式配置来实现实体和数据库之间存在某种映射关系
- Hibernate(三)结构-配置文件-实体映射及配置文件
- ant深入浅出(一)ant+xdoclet 生成hibernate配置文件以及实体映射文件
- Hibernate学习笔记(2)——搭建项目框架编写hibernate配置文件、实体映射文件