Hibernate进阶之多对多双向关联

2024-04-16 13:32

本文主要是介绍Hibernate进阶之多对多双向关联,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

package cn.itcast.d_many22many;import java.util.Date;
import java.util.HashSet;
import java.util.Set;import javassist.expr.NewArray;/*** 项目* * @author Jie.Yuan* */
public class Student {private int id;private String name;private Set<Teacher> teachers=new HashSet<Teacher>();public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Set<Teacher> getTeachers() {return teachers;}public void setTeachers(Set<Teacher> teachers) {this.teachers = teachers;}@Overridepublic String toString() {return "Student [id=" + id + ", name=" + name + ", teachers="+ teachers + "]";}
}

package cn.itcast.d_many22many;import java.util.HashSet;
import java.util.Set;import javassist.expr.NewArray;/*** 开发人员* * @author Jie.Yuan* */
public class Teacher {private int id;private String name;private Set<Student> students;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Set<Student> getStudents() {return students;}public void setStudents(Set<Student> students) {this.students = students;}@Overridepublic String toString() {return "Teacher [id=" + id + ", name=" + name + ", students="+ students + "]";}}

student.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><hibernate-mapping package="cn.itcast.d_many22many"><class name="Student" table="student"><id name="id"><generator class="native"></generator></id><property name="name" column="name"/><set name="teachers" table="teacher_student"><key column="student_id"></key><!-- 查找这个学生被那个老师教 --><many-to-many class="Teacher" column="teacher_id"></many-to-many></set></class></hibernate-mapping>


teacher.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><hibernate-mapping package="cn.itcast.d_many22many"><class name="Teacher" table="teacher"><id name="id" column="id"><generator class="native"></generator></id><property name="name" 		column="name" /><set name="students" table="teacher_student"><!--查老师的id的  和中间表联系--><key column="teacher_id"/><!-- 查学生的id和中间表的关系 --><many-to-many class="Student" column="student_id"></many-to-many></set></class>
</hibernate-mapping>


测试类

package cn.itcast.d_many22many;import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;import org.hibernate.classic.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.junit.Test;import cn.itcast.d_many22many.Student;
import cn.itcast.d_many22many.Teacher;public class App_many22many {//双向多对多private static SessionFactory sf;static {sf = new Configuration().configure().addClass(Student.class)   .addClass(Teacher.class)   // 测试时候使用.buildSessionFactory();}@Testpublic void add(){Session session = sf.openSession();session.beginTransaction();Teacher t1 = new Teacher();t1.setName("王老师");Teacher t2 = new Teacher();t2.setName("李老师");Student s1 = new Student();s1.setName("王同学");Student s2 = new Student();s2.setName("李同学");Set<Student> ss = new HashSet<Student>();ss.add(s1);ss.add(s2);t1.setStudents(ss);// 告诉Hibernate老师教了那两个学生t2.setStudents(ss);session.save(t1);session.save(t2);session.save(s1);session.save(s2);session.getTransaction().commit();session.close();}@Testpublic void query(){//双向关联体现在查找上Session session = sf.openSession();session.beginTransaction();Teacher teacher = (Teacher) session.get(Teacher.class, 2);System.out.println("教室的姓名:" + teacher.getName());System.out.println("教室的学生列表:");Iterator<Student> iterator = teacher.getStudents().iterator();while (iterator.hasNext()) {Student student = iterator.next();System.out.println(student.getName() + "   ");}System.out.println("===========逆向==============");Student student = (Student) session.get(Student.class, 1);System.out.println("学生的姓名:" + student.getName());System.out.println("学生被教的老师:");Iterator<Teacher> iterator2 = student.getTeachers().iterator();while (iterator2.hasNext()) {Teacher teacher2 = iterator2.next();System.out.println(teacher2.getName() + "  ");}System.out.println();session.getTransaction().commit();session.close();}
}



这篇关于Hibernate进阶之多对多双向关联的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/908921

相关文章

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

MySQL进阶之路索引失效的11种情况详析

《MySQL进阶之路索引失效的11种情况详析》:本文主要介绍MySQL查询优化中的11种常见情况,包括索引的使用和优化策略,通过这些策略,开发者可以显著提升查询性能,需要的朋友可以参考下... 目录前言图示1. 使用不等式操作符(!=, <, >)2. 使用 OR 连接多个条件3. 对索引字段进行计算操作4

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

MYSQL关联关系查询方式

《MYSQL关联关系查询方式》文章详细介绍了MySQL中如何使用内连接和左外连接进行表的关联查询,并展示了如何选择列和使用别名,文章还提供了一些关于查询优化的建议,并鼓励读者参考和支持脚本之家... 目录mysql关联关系查询关联关系查询这个查询做了以下几件事MySQL自关联查询总结MYSQL关联关系查询

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin