Hibernate-多对多ManyToMany

例子:

  • 学生与课程之间多对多关系

  • 如果想要知道学生选了哪些课,需要在学生类配置ManyToMany,

  • 如果想要知道该课程有哪些学生,需要在课程类配置ManyToMany

  • 如果以上两种都需要,则在两边都得配置ManyToMany

  • 无论哪一种配置,表结构都一样(都有中间表自动生成),只是表之间关系在对表操作时有限制(比如只在学生类配置了ManyToMany,则无法通过课程查询学生),表结构如下:
    在这里插入图片描述

单边配置ManyToMany,如下:

Student.java

public class Student {
	private int id;
	private String name;
    private Set<Course> courses;
    //get、set省略
   } 

Student.hbm.xml
在这里插入图片描述
Course.java

public class Course {
	private int id;
	private String name;
    //get、set省略
   } 

Course.hbm.xml
在这里插入图片描述

  • 添加数据
    /*
	 *两名学生选了两门相同的课程
	 */
	public void testAdd(){
		Course c1 = new Course();
		c1.setName("Java");
		
		Course c2 = new Course();
		c2.setName("C#");
		
		Set<Course> set = new HashSet<Course>();
		set.add(c1);
		set.add(c2);
		
		Student s1 =  new Student();
		s1.setName("Tom");
		s1.setCourses(set);
		
		Student s2 =  new Student();
		s2.setName("Jack");
		s2.setCourses(set);
		
		Session session =null;
		try{
			session = HibernateUtil.getSession();
			session.beginTransaction();
			session.save(c1);
			session.save(c2);
			session.save(s1);
			session.save(s2);
			session.getTransaction().commit();
		}catch(Exception e){
			session.getTransaction().rollback();
			e.printStackTrace();
		}finally{
			HibernateUtil.closeSession(session); 
		}
	}
  • 结果
    在这里插入图片描述
    在这里插入图片描述
  • 查询学号为1的学生所选的课程
public void testLoad(){
		
		
		Student s =  new Student();

		Session session =null;
		try{
			session = HibernateUtil.getSession();
			session.beginTransaction();

			s = (Student)session.load(Student.class, 1);
			System.out.println("Student Name:"+s.getName());
			for(Course c: s.getCourses()){
				System.out.println("Course Name:"+c.getName());
			}
			session.getTransaction().commit();
		}catch(Exception e){
			session.getTransaction().rollback();
			e.printStackTrace();
		}finally{
			HibernateUtil.closeSession(session); 
		}
	}

两边都配置ManyToMany(跟单边配置一样,就是两边都要),如下:

Student.java

public class Student {
	private int id;
	private String name;
    private Set<Course> courses;
    //get、set省略
   }

Student.hbm.xml
在这里插入图片描述
Course.java

public class Course {
	private int id;
	private String name;
	private Set<Student> students;
    //get、set省略
   }

Course.hbm.xml
在这里插入图片描述

  • 添加数据:如果原来是单边配置,现在改成双边配置ManyToMany,原来的表数据不会改变,只是表结构多了一个关系,所以不需要担心原来的数据会改变。
public void testAdd(){
		Course c1 = new Course();
		c1.setName("Java");
		
		Course c2 = new Course();
		c2.setName("C#");
		
		Set<Course> set = new HashSet<Course>();
		set.add(c1);
		set.add(c2);
		
		Student s1 =  new Student();
		s1.setName("Tom");
		s1.setCourses(set);
		
		Student s2 =  new Student();
		s2.setName("Jack");
		s2.setCourses(set);
		
		Session session =null;
		try{
			session = HibernateUtil.getSession();
			session.beginTransaction();
			session.save(c1);
			session.save(c2);
			session.save(s1);
			session.save(s2);
			session.getTransaction().commit();
		}catch(Exception e){
			session.getTransaction().rollback();
			e.printStackTrace();
		}finally{
			HibernateUtil.closeSession(session); 
		}
	}
  • 查学号为1的学生所选的课程
public void testLoad(){
		
		
		Student s =  new Student();

		Session session =null;
		try{
			session = HibernateUtil.getSession();
			session.beginTransaction();

			s = (Student)session.load(Student.class, 1);
			System.out.println("Student Name:"+s.getName());
			for(Course c: s.getCourses()){
				System.out.println("Course Name:"+c.getName());
			}
			session.getTransaction().commit();
		}catch(Exception e){
			session.getTransaction().rollback();
			e.printStackTrace();
		}finally{
			HibernateUtil.closeSession(session); 
		}
	}
  • 查课程号为1的课有哪些学生
public void testLoad2(){
		
		
		Course c =  new Course();
	
		Session session =null;
		try{
			session = HibernateUtil.getSession();
			session.beginTransaction();
	
			c = (Course)session.load(Course.class, 1);
			System.out.println("Course Name:"+c.getName());
			for(Student s: c.getStudents()){
				System.out.println("Student Name:"+s.getName());
			}
			session.getTransaction().commit();
		}catch(Exception e){
			session.getTransaction().rollback();
			e.printStackTrace();
		}finally{
			HibernateUtil.closeSession(session); 
		}
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值