多对多映射是我在之前所说的映射里边稍微复杂的,但是理解起来也是相当容易的。如下图:
只需要借助一张表作为中介,管理User 和 Role 之间的关系即可。这样,一个用户可以拥有多个角色,一个角
色可以对应多个用户。
看看代码如何实现,新建User实体类对象:
package com.bjpowernode.hibernate;
import java.util.Set;
public class User {
private int id;
private String name;
private Set role;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set getRole() {
return role;
}
public void setRole(Set role) {
this.role = role;
}
}
配置User.hbm.xml映射文件:
<?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>
<class name="com.bjpowernode.hibernate.User" table="t_user" >
<id name="id">
<generator class="native"/>
</id>
<property name="name"/>
<set name="role" table="t_user_role">
<key column="user_id"/>
<many-to-many class="com.bjpowernode.hibernate.Role" column="role_id"/>
</set>
</class>
</hibernate-mapping>
新建Role实体对象:
package com.bjpowernode.hibernate;
import java.util.Set;
/**
* 建立User实体类
* @author why_768
*
*/
public class Role {
private int id;
private String name;
private Set users;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set getUsers() {
return users;
}
public void setUsers(Set users) {
this.users = users;
}
}
配置Role.hbm.xml映射文件:
<?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>
<class name="com.bjpowernode.hibernate.Role" table="t_role">
<id name="id">
<generator class="native"/>
</id>
<property name="name"/>
<set name="users" table="t_user_role">
<key column="role_id"/>
<many-to-many class="com.bjpowernode.hibernate.User" column="user_id"/>
</set>
</class>
</hibernate-mapping>
新建数据库,导出的数据库表,将会生成第三张关联表:t_user_role:
建立Junit测试类保存数据:
public void testSave1(){
Session session = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
Role role1 = new Role();
role1.setName("Zj's Family");
session.save(role1);
Role role2 = new Role();
role2.setName("Master");
session.save(role2);
Set roles = new HashSet();
roles.add(role1);
roles.add(role2);
User user1 = new User();
user1.setName("Yana");
user1.setRole(roles);
session.save(user1);
User user2 = new User();
user2.setName("XLB");
user2.setRole(roles);
session.save(user2);
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
} finally{
HibernateUtils.closeSession(session);
}
}
查看数据库数据:
到这里,Hibernate的相关映射关系小编就总结的差不多了,嘻嘻~~~