1 hibernate多对多关联映射(双向User<---->Role)
映射方法:
<set name="roles" table="t_user_role">
<key column="userid"/>
<many-to-many class="com.bjsxt.hibernate.Role" column="roleid"/>
</set>
table属性值必须和单向关联中的table属性值一致
<key>中column属性值要与单向关联中的<many-to-many>标签中的column属性值一致
在<many-to-many>中的column属性值要与单向关联中<key>标签的column属性值一致
一:实体类:
- package com.tao.hibernate.many2many2;
- import java.util.Set;
- public class Role {
- private Integer id;
- private String name;
- private Set<User> users;
- public Role() {
- super();
- }
- 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 Set<User> getUsers() {
- return users;
- }
- public void setUsers(Set<User> users) {
- this.users = users;
- }
- }
package com.tao.hibernate.many2many2; import java.util.Set; public class Role { private Integer id; private String name; private Set<User> users; public Role() { super(); } 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 Set<User> getUsers() { return users; } public void setUsers(Set<User> users) { this.users = users; } }
- package com.tao.hibernate.many2many2;
- import java.util.Set;
- public class User {
- private Integer id;
- private String name;
- private Set<Role> roles;
- public User() {
- super();
- }
- 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 Set<Role> getRoles() {
- return roles;
- }
- public void setRoles(Set<Role> roles) {
- this.roles = roles;
- }
- }
package com.tao.hibernate.many2many2; import java.util.Set; public class User { private Integer id; private String name; private Set<Role> roles; public User() { super(); } 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 Set<Role> getRoles() { return roles; } public void setRoles(Set<Role> roles) { this.roles = roles; } }
二:映射文件:
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping package="com.tao.hibernate.many2many2"
- auto-import="false">
- <class name="Role" table="t_role">
- <id name="id" column="id" type="integer">
- <generator class="native">
- </generator>
- </id>
- <property name="name" column="name" />
- <set name="users" table="t_user_role" order-by="userId">
- <key column="roleId" />
- <many-to-many class="User" column="userId" />
- </set>
- </class>
- </hibernate-mapping>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.tao.hibernate.many2many2" auto-import="false"> <class name="Role" table="t_role"> <id name="id" column="id" type="integer"> <generator class="native"> </generator> </id> <property name="name" column="name" /> <set name="users" table="t_user_role" order-by="userId"> <key column="roleId" /> <many-to-many class="User" column="userId" /> </set> </class> </hibernate-mapping>
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping package="com.tao.hibernate.many2many2"
- auto-import="false">
- <class name="User" table="t_user">
- <id name="id" column="id" type="integer">
- <generator class="native">
- </generator>
- </id>
- <property name="name" column="name" />
- <set name="roles" table="t_user_role" cascade="all">
- <key column="userId" />
- <many-to-many class="Role" column="roleId" />
- </set>
- </class>
- </hibernate-mapping>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.tao.hibernate.many2many2" auto-import="false"> <class name="User" table="t_user"> <id name="id" column="id" type="integer"> <generator class="native"> </generator> </id> <property name="name" column="name" /> <set name="roles" table="t_user_role" cascade="all"> <key column="userId" /> <many-to-many class="Role" column="roleId" /> </set> </class> </hibernate-mapping>
三:测试类:
- package com.tao.hibernate.many2many2;
- import java.util.Iterator;
- import org.hibernate.Session;
- import org.junit.Test;
- import com.tao.hibernate.HibernateUtils;
- public class TestMain {
- Session session = HibernateUtils.getFactory().openSession();
- @Test
- public void testLoad() {
- Session session = HibernateUtils.getFactory().openSession();
- Role r1 = (Role) session.load(Role.class, 1);
- System.out.println(r1.getName());
- for (Iterator<User> iter = r1.getUsers().iterator(); iter.hasNext();) {
- System.out.println(iter.next().getName());
- }
- }
- }
Student.java
- package com.entity;
- import java.io.Serializable;
- import java.util.HashSet;
- import java.util.Set;
- import javax.persistence.Column;
- import javax.persistence.Entity;
- import javax.persistence.GeneratedValue;
- import javax.persistence.Id;
- import javax.persistence.ManyToMany;
- import javax.persistence.Table;
- @Entity
- @Table(name = "Student")
- publicclass Student implements Serializable {
- private Integer studentid;//学生ID
- private String studentName;//学生姓名
- private Set<Teacher> teachers = new HashSet<Teacher>();//对应的教师集合
- public Student() {
- }
- public Student(String studentName) {
- this.studentName = studentName;
- }
- @Id
- @GeneratedValue
- public Integer getStudentid() {
- return studentid;
- }
- publicvoid setStudentid(Integer studentid) {
- this.studentid = studentid;
- }
- @Column(nullable = false, length = 32)
- public String getStudentName() {
- return studentName;
- }
- publicvoid setStudentName(String studentName) {
- this.studentName = studentName;
- }
- /*
- * @ManyToMany 注释表示Student是多对多关系的一边,mappedBy 属性定义了Student 为双向关系的维护端
- */
- @ManyToMany(mappedBy = "students")
- public Set<Teacher> getTeachers() {
- return teachers;
- }
- publicvoid setTeachers(Set<Teacher> teachers) {
- this.teachers = teachers;
- }
- }
package com.entity; import java.io.Serializable; import java.util.HashSet; import java.util.Set; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.ManyToMany; import javax.persistence.Table; @Entity @Table(name = "Student") public class Student implements Serializable { private Integer studentid;//学生ID private String studentName;//学生姓名 private Set<Teacher> teachers = new HashSet<Teacher>();//对应的教师集合 public Student() { } public Student(String studentName) { this.studentName = studentName; } @Id @GeneratedValue public Integer getStudentid() { return studentid; } public void setStudentid(Integer studentid) { this.studentid = studentid; } @Column(nullable = false, length = 32) public String getStudentName() { return studentName; } public void setStudentName(String studentName) { this.studentName = studentName; } /* * @ManyToMany 注释表示Student是多对多关系的一边,mappedBy 属性定义了Student 为双向关系的维护端 */ @ManyToMany(mappedBy = "students") public Set<Teacher> getTeachers() { return teachers; } public void setTeachers(Set<Teacher> teachers) { this.teachers = teachers; } }
多对多的关联的中间表
Teacher.java
- package com.entity;
- import java.io.Serializable;
- import java.util.HashSet;
- import java.util.Set;
- import javax.persistence.CascadeType;
- import javax.persistence.Column;
- import javax.persistence.Entity;
- import javax.persistence.FetchType;
- import javax.persistence.GeneratedValue;
- import javax.persistence.Id;
- import javax.persistence.JoinTable;
- import javax.persistence.ManyToMany;
- import javax.persistence.Table;
- import javax.persistence.JoinColumn;
- @Entity
- @Table
- publicclass Teacher implements Serializable {
- private Integer teacherid;// 教师ID
- private String teacherName;// 教师姓名
- private Set<Student> students = new HashSet<Student>();// 对应的学生集合
- public Teacher() {
- }
- public Teacher(String teacherName) {
- this.teacherName = teacherName;
- }
- @Id
- @GeneratedValue
- public Integer getTeacherid() {
- return teacherid;
- }
- publicvoid setTeacherid(Integer teacherid) {
- this.teacherid = teacherid;
- }
- @Column(nullable = false, length = 32)
- public String getTeacherName() {
- return teacherName;
- }
- publicvoid setTeacherName(String teacherName) {
- this.teacherName = teacherName;
- }
- /*
- * @ManyToMany 注释表示Teacher 是多对多关系的一端。
- * @JoinTable 描述了多对多关系的数据表关系,name属性指定中间表名称。
- * joinColumns 定义中间表与Teacher 表的外键关系,中间表Teacher_Student的Teacher_ID 列是Teacher 表的主键列对应的外键列。
- * inverseJoinColumns 属性定义了中间表与另外一端(Student)的外键关系。
- */
- @ManyToMany(cascade = CascadeType.PERSIST, fetch = FetchType.LAZY)
- @JoinTable(name = "Teacher_Student",
- joinColumns ={@JoinColumn(name = "teacher_ID", referencedColumnName = "teacherid") },
- inverseJoinColumns = { @JoinColumn(name = "student_ID", referencedColumnName = "studentid")
- })
- public Set<Student> getStudents() {
- return students;
- }
- publicvoid setStudents(Set<Student> students) {
- this.students = students;
- }
- publicvoid addStudent(Student student) {
- if (!this.students.contains(student)) {//检测在该散列表中某些键是否映射到指定值,value 查找的值。如果某些键映射到该散列表中的值为true,否则false
- this.students.add(student);
- }
- }
- publicvoid removeStudent(Student student) {
- this.students.remove(student);
- }
- }