jpa多对多映射案例
2011-01-31 16:32
204 查看
学生和老师就是多对多的关系。一个学生有多个老师,一个老师教多个学生。多对多映射采取中间表连接的映射策略,建立的中间表将分别引入两边的主键作为外键。jpa 对于中间表的元数据提供了可配置的方式,用户可以自定义中间表的表名,列名。
下面就以学生和老师为例介绍多对多映射关系的实例开发
Student实体类
Teacher实体类
ManyToManyTest测试类
下面就以学生和老师为例介绍多对多映射关系的实例开发
Student实体类
package com.ljq.entity; 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; @SuppressWarnings("serial") @Entity public class Student implements java.io.Serializable { /** 学生ID **/ private Integer studentid; /** 学生姓名 **/ private String name; private Set<Teacher> teachers=new HashSet<Teacher>(); public Student() { super(); } public Student(String name) { super(); this.name = name; } @Id @GeneratedValue public Integer getStudentid() { return studentid; } public void setStudentid(Integer studentid) { this.studentid = studentid; } @Column(nullable=false,length=32) public String getName() { return name; } public void setName(String name) { this.name = name; } //@ManyToMany注释表示Student是多对多关系的一边,mappedBy属性定义了Student为双向关系的维护端 //Teacher表是关系的维护者,owner side,有主导权,它有个外键指向Student表。 @ManyToMany(mappedBy = "students") public Set<Teacher> getTeachers() { return teachers; } public void setTeachers(Set<Teacher> teachers) { this.teachers = teachers; } }
Teacher实体类
package com.ljq.entity; 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.JoinColumn; import javax.persistence.JoinTable; import javax.persistence.ManyToMany; @SuppressWarnings("serial") @Entity public class Teacher implements java.io.Serializable { /** 教师ID **/ private Integer teacherid; /** 教师姓名 **/ private String name; private Set<Student> students=new HashSet<Student>(); public Teacher() { super(); } public Teacher(String name) { super(); this.name = name; } @Id @GeneratedValue public Integer getTeacherid() { return teacherid; } public void setTeacherid(Integer teacherid) { this.teacherid = teacherid; } @Column(nullable=false,length=32) public String getName() { return name; } public void setName(String name) { this.name = name; } //@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; } public void setStudents(Set<Student> students) { this.students = students; } /** * 添加学生 * * @param student */ public void addStudent(Student student) { if (!this.students.contains(student)) { this.students.add(student); student.setTeacher(this); } } /** * 删除学生 * * @param student */ public void removeStudent(Student student) { if(this.students.contains(student)){ student.setTeacher(null); this.students.remove(student); } } }
ManyToManyTest测试类
package com.ljq.test; import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; import org.junit.Test; import com.ljq.entity.Student; import com.ljq.entity.Teacher; public class ManyToManyTest { @Test public void save() { EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq"); EntityManager em=factory.createEntityManager(); em.getTransaction().begin(); em.persist(new Teacher("张老师")); em.persist(new Student("小张")); em.getTransaction().commit(); em.close(); factory.close(); } /** * 为老师添加一个学生 * */ @Test public void build() { EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq"); EntityManager em=factory.createEntityManager(); em.getTransaction().begin(); Teacher teacher = em.find(Teacher.class, 2); teacher.addStudent(em.getReference(Student.class, 2)); em.getTransaction().commit(); em.close(); factory.close(); } /** * 解除学生跟老师的关系 * */ @Test public void remove() { EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq"); EntityManager em=factory.createEntityManager(); em.getTransaction().begin(); Teacher teacher = em.find(Teacher.class, 2); teacher.removeStudent(em.getReference(Student.class, 2)); em.getTransaction().commit(); em.close(); factory.close(); } /** * 删除学生,因为学生不是关系维护者,所以需要先手工解除老师与学生的关联,然后再删除学生 * */ @Test public void deleteStudent() { EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq"); EntityManager em=factory.createEntityManager(); em.getTransaction().begin(); Teacher teacher = em.find(Teacher.class, 2); Student student = em.getReference(Student.class, 2); teacher.removeStudent(student); //手工解除老师与学生的关系 em.remove(student); //删除学生 em.getTransaction().commit(); em.close(); factory.close(); } /** * 删除老师,因为老师是关系维护者,所以可以直接解除老师与学生的关系,不用我们手工解除 * */ @Test public void deleteTeacher() { EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq"); EntityManager em=factory.createEntityManager(); em.getTransaction().begin(); em.remove(em.getReference(Teacher.class, 3)); em.getTransaction().commit(); em.close(); factory.close(); } /** * 用来判断映射是否成功 * */ @Test public void test() { EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq"); factory.close(); } }
相关文章推荐
- JPA一对一映射案例
- jpa一对一映射案例
- jpa一对多映射案例
- jpa多对多映射案例
- jpa一对多映射案例
- jpa一对多映射案例
- JPA映射文件和注解解释
- 通过 Hibernate 实现 JPA 对象关系模型之继承映射策略
- 综合实战:Java映射(简单案例)
- Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
- SPRING MVC3.2案例讲解--SPRING MVC3的各种URL映射(3)
- SpringMvc的Url映射和传参案例
- 持久化API(JPA)系列(八)实体关系映射(ORM)之单表映射@EmbeddedId
- JPA——映射持久化对象(Entity)
- JPA总结——实体关系映射(一对一@OneToOne)
- JPA基础(十四):JPA中的继承映射关系
- JPA关系映射之one-to-many和many-to-one
- JPA 关系映射(OneToOne、OneToMany、ManyToMany)
- JPA的继承映射
- 持久化API(JPA)系列(六)实体关系映射(ORM)之映射类型