JPA:双向多对多关系

10 篇文章 1 订阅

例如学生和老师之间的多对多关系

Teacher.java

import java.util.HashSet;
import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.ManyToMany;

@Entity
public class Teacher {
    private Integer id;
    private String name;
    private Set<Student> student=new HashSet<Student>();
    
    
    public Teacher() {}
    public Teacher(String name) {
        this.name = name;
    }
    @ManyToMany(cascade=CascadeType.REFRESH,mappedBy="teachers")
    public Set<Student> getStudent() {
        return student;
    }

    public void setStudent(Set<Student> student) {
        this.student = student;
    }
    @Id @GeneratedValue
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    @Column(length=10,nullable=false)
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((id == null) ? 0 : id.hashCode());
        return result;
    }
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Teacher other = (Teacher) obj;
        if (id == null) {
            if (other.id != null)
                return false;
        } else if (!id.equals(other.id))
            return false;
        return true;
    }

    
}

Student.java
import java.util.HashSet;
import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;

@Entity
public class Student {
    private Integer id;
    private String name;
    private Set<Teacher> teachers=new HashSet<Teacher>();
    
    
    
    public Student() {
    }
    public Student(String name) {
        this.name = name;
    }
    @ManyToMany(cascade=CascadeType.REFRESH)
    @JoinTable(name="student_teacher",inverseJoinColumns=@JoinColumn(name="teacher_id"),
            joinColumns=@JoinColumn(name="student_id"))

    public Set<Teacher> getTeachers() {
        return teachers;
    }
    public void setTeachers(Set<Teacher> teachers) {
        this.teachers = teachers;
    }
    public void addTeacher(Teacher teacher){
        this.teachers.add(teacher);
    }
    public void removeTeacher(Teacher teacher){
        if(this.teachers.contains(teacher)){
            this.teachers.remove(teacher);
        }
        
    }

    
    @Id @GeneratedValue
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    @Column(length=10,nullable=false)
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    
}

操作测试

@Test
    public void save(){
        EntityManagerFactory factory=Persistence.createEntityManagerFactory("unitName");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        em.persist(new Student("小张"));
        em.persist(new Teacher("李勇老师"));//他们之间没有任何关系

        em.getTransaction().commit();
        em.close();
        factory.close();
    }
    /**
     * 建立学生跟老师的关系,托管状态
     */
    @Test
    public void buildTS(){
        EntityManagerFactory factory=Persistence.createEntityManagerFactory("unitName");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        Student student=em.find(Student.class, 1);
        student.addTeacher(em.getReference(Teacher.class, 1));//通过关系维护端,中间表添加一条记录

        em.getTransaction().commit();
        em.close();
        factory.close();
    }    
    
    /**
     * 解除学生跟老师的关系,托管状态
     */
    @Test
    public void deleteTS(){
        EntityManagerFactory factory=Persistence.createEntityManagerFactory("unitName");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        Student student=em.find(Student.class, 1);
        student.removeTeacher(em.getReference(Teacher.class, 1));//通过关系维护端,中间表删除相应的一条记录

        em.getTransaction().commit();
        em.close();
        factory.close();
    }        
    
    /**
     * 删除老师
     */
    @Test
    public void deleteTeacher(){
        EntityManagerFactory factory=Persistence.createEntityManagerFactory("unitName");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        Student student=em.find(Student.class, 1);
        Teacher teacher=em.getReference(Teacher.class, 1);
        student.removeTeacher(teacher);        //必须把集合中这个老师删除,因为这个是关系维护端
        em.remove(teacher);

        em.getTransaction().commit();
        em.close();
        factory.close();
    }        
    /**
     * 删除学生
     */
    @Test
    public void deleteStudent(){
        EntityManagerFactory factory=Persistence.createEntityManagerFactory("unitName");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        Student student=em.find(Student.class, 1);//因为是关系维护端,所以在中间表那个字段置为null
        em.remove(student);

        em.getTransaction().commit();
        em.close();
        factory.close();
    }           

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值