hibernate自主学习,汤阳光hibernate视频例子。
视频中又说到解除老师—学生,学生—老师的双向关系的例子。用的方法是:
teacher.getStudents().clear();// 解除与这老师有关联关系的所有学生,所有,可能移除多条关联关系,也有可能一条都没有或只有一条关联关系
student.getTeachers().clear();// 解除与这学生有关联关系的所有老师,所有,可能移除多条关联关系,也有可能一条都没有或只有一条关联关系
而在现实中我们可能只移除一条关联关系,后来我自己去查了看,有这么一个方法可是实现这一个功能:
Teacher teacher_1 = (Teacher) session.get(Teacher.class, 7L); // 从数据库中获取7号教师,7L表示长整数类型7先获得操作对象(teacher_1,student_1),和与之要移除关联关系的被移除对象(student_1,teacher_1),用remove()函数,就能实现解除单一的关联关系。
Student student_1 = (Student) session.get(Student.class, 7L); // 从数据库中获取7号学生,7L表示长整数类型7
//从老师方移除与该学生有关的关联关系,仅仅移除一条关联关系
teacher_1.getStudents().remove(student_1);
//从学生方移除与该老师有关的关联关系,仅仅移除一条关联关系
student_1.getTeachers().remove(teacher_1);
具体函数:
/**
* 解除关联关系
*/
@Test
public void testRemoveRelationship() {
// 从老师方解除关联关系
Teacher teacher = (Teacher) session.get(Teacher.class, 7L); // 从数据库中获取7号教师,7L表示长整数类型7
teacher.getStudents().clear();// 解除与这老师有关联关系的所有学生,可能移除多条关联关系,也有可能一条都没有或只有一条关联关系
// 从学生方解除关联关系
Student student = (Student) session.get(Student.class, 7L); // 从数据库中获取7号学生,7L表示长整数类型7
student.getTeachers().clear();// 解除与这学生有关联关系的所有老师,可能移除多条关联关系,也有可能一条都没有或只有一条关联关系
/**
* 从学生方或老师方解除关联关系,不会删除学生表、老师表中信息,只会在关联关系表中移除关系。与删除老师或学生不同
*/
Teacher teacher_1 = (Teacher) session.get(Teacher.class, 7L); // 从数据库中获取7号教师,7L表示长整数类型7
Student student_1 = (Student) session.get(Student.class, 7L); // 从数据库中获取7号学生,7L表示长整数类型7
//从老师方移除与该学生有关的关联关系,仅仅移除一条关联关系
teacher_1.getStudents().remove(student_1);
//从学生方移除与该老师有关的关联关系,仅仅移除一条关联关系
student_1.getTeachers().remove(teacher_1);
transaction.commit();
session.close();
}
小小知识点,有待提高。