------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------

本篇博客将讲述Hibernate中的多对多关联关系的操作,准备的篇幅较少,望海涵

一,讲述多对多

  多对多的关联关系,比如学生和教师来说,一个学生由多个教师授课,一个教师授课给多个学生,这就是多对多

  讲述多对多,首先要有一个表叫做中间表,他来承载关联关系

二,实体类的创建

  1.Stu学生类创建:

package cn.dawn.day04.entity;

/**
* Created by Dawn on 2018/6/2.
*/
import java.io.Serializable;
import java.util.Set; /*学生实体类*/
public class Stu implements Serializable{
private Long sid;
private String sname;
/*教师对象集合*/
private Set<Tea> teas;
public Long getSid() {
return sid;
} public void setSid(Long sid) {
this.sid = sid;
} public String getSname() {
return sname;
} public void setSname(String sname) {
this.sname = sname;
} public Set<Tea> getTeas() {
return teas;
} public void setTeas(Set<Tea> teas) {
this.teas = teas;
}
}

  2.Tea教室类的创建:

package cn.dawn.day04.entity;

import java.io.Serializable;
import java.util.Set; /**
* Created by Dawn on 2018/6/2.
*/
/*教师实体类*/
public class Tea implements Serializable {
private Long tid;
private String tname;
/*学生对象集合*/
private Set<Stu> stus; public Long getTid() {
return tid;
} public void setTid(Long tid) {
this.tid = tid;
} public String getTname() {
return tname;
} public void setTname(String tname) {
this.tname = tname;
} public Set<Stu> getStus() {
return stus;
} public void setStus(Set<Stu> stus) {
this.stus = stus;
}
}

三,hbm.xml文件的创建

  1.Stu.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.dawn.day04.entity">
<!--如果上面指定package的话,class的name就不必写全类名-->
<!--lazy:是否懒加载(延迟加载) 默认值是true,延迟加载-->
<!--<class name="Teacher">-->
<!--直接加载-->
<class name="Stu" lazy="false">
<!--主键-->
<id name="sid" column="sid">
<!--主键生成策咯 assigned程序员自己创建-->
<!--identity是mysql里的自增,一会做增加操作不必再给主键赋值-->
<!--increment是先查最大的主键列,在下一条给主键加一-->
<!--sequence是oracle的主键生成策咯,他一会需要指定序列名字<param name="sequence">序列名</param>-->
<generator class="increment"></generator>
</id>
<property name="sname" column="tname"></property>
<!--table指的是中间表,承载关联关系的表-->
<set name="teas" table="tea_stu" cascade="save-update" inverse="false">
<key>
<!--本类表的id-->
<column name="sid"></column>
</key>
<!--另外与他有多对多关联的实体类-->
<many-to-many class="Tea" column="tid"></many-to-many>
</set>
</class>
</hibernate-mapping>

  2.Tea.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.dawn.day04.entity">
<!--如果上面指定package的话,class的name就不必写全类名-->
<!--lazy:是否懒加载(延迟加载) 默认值是true,延迟加载-->
<!--<class name="Teacher">-->
<!--直接加载-->
<class name="Tea" lazy="false">
<!--主键-->
<id name="tid" column="tid">
<!--主键生成策咯 assigned程序员自己创建-->
<!--identity是mysql里的自增,一会做增加操作不必再给主键赋值-->
<!--increment是先查最大的主键列,在下一条给主键加一-->
<!--sequence是oracle的主键生成策咯,他一会需要指定序列名字<param name="sequence">序列名</param>-->
<generator class="increment"></generator>
</id>
<property name="tname" column="tname"></property>
<!--table指的是中间表,承载关联关系的表-->
<set name="stus" table="tea_stu" cascade="save-update" inverse="false">
<key>
<!--本类表的id-->
<column name="tid"></column>
</key>
<!--另外与他有多对多关联的实体类-->
<many-to-many class="Stu" column="sid"></many-to-many>
</set>
</class>
</hibernate-mapping>

四,hibernate.cfg.xml中管理上方俩个hbm.xml小配置文件

        <!--与小配置文件映射-->
<mapping resource="cn/dawn/day04/dao/Tea.hbm.xml"></mapping>
<mapping resource="cn/dawn/day04/dao/Stu.hbm.xml"></mapping>

五,单测方法:

    @Test
/*同时保存,并建立关联关系*/
public void t1ManyToManyInsert(){
/*
* 新建一个教师
*/
Tea tea1=new Tea();
tea1.setTname("老雨");
/**
* 新建俩个学生
*/
Stu stu1=new Stu();
stu1.setSname("小六");
Stu stu2=new Stu();
stu2.setSname("小八"); Set<Stu> students = new HashSet<Stu>();
students.add(stu1);
students.add(stu2);
/**
* 通过课程建立课程与学生之间的关系
*/
tea1.setStus(students);//因为课程是一个新的,所以根据没有学生
/*新增*/
session.save(tea1);
/*事务提交*/
tr.commit(); /*
Hibernate: create table Stu (sid bigint not null, tname varchar(255), primary key (sid)) engine=MyISAM
Hibernate: create table Tea (tid bigint not null, tname varchar(255), primary key (tid)) engine=MyISAM
Hibernate: create table tea_stu (tid bigint not null, sid bigint not null, primary key (sid, tid)) engine=MyISAM
Hibernate: alter table tea_stu add constraint FK1lo22k662lgxr7d79rmfajlu3 foreign key (sid) references Stu (sid)
Hibernate: alter table tea_stu add constraint FKgq01y04i2r2ye5pd8abh5x42u foreign key (tid) references Tea (tid)
Hibernate: select max(tid) from Tea
Hibernate: select max(sid) from Stu
Hibernate: insert into Tea (tname, tid) values (?, ?)
Hibernate: insert into Stu (tname, sid) values (?, ?)
Hibernate: insert into Stu (tname, sid) values (?, ?)
Hibernate: insert into tea_stu (tid, sid) values (?, ?)
Hibernate: insert into tea_stu (tid, sid) values (?, ?)
* */
}

六,总结:

  我认为此处写的已经足够,最好的学习方法就是尝试,自己来试一下

  我可以提出需求:

    1.保存单个学生

    2.修改一个教师下关联的学生

    3.将一个学生关联的所有教师都干掉

    等等等。。。。。。。。。。。。。

Hibernate-ORM:12.Hibernate中的多对多关联关系的更多相关文章

  1. Hibernate双向一对多、双向多对多关联关系中的映射文件怎么写

    这里以一对多关联关系为例.以Country类为一端,Competition类为多端. 一个国家可以有多个赛事,但是一个赛事只能属于一个国家. Country类 public class Country ...

  2. 【SSH三大框架】Hibernate基础第六篇:多对一关联关系的映射、分析及加入、查询

    这里举样例用的是:部门与员工的关系. 一个部门能够相应多个员工,这就是非常明显的多对一关联关系. 我们须要建立两个实体类:员工(Employee).部门(Department) 员工类:Employe ...

  3. (转)Hibernate框架基础——多对多关联关系映射

    http://blog.csdn.net/yerenyuan_pku/article/details/52756536 多对多关联关系映射 多对多的实体关系模型也是很常见的,比如学生和课程的关系.一个 ...

  4. Hibernate中双向多对多的两种配置方式

    Hibernate中双向多对多的两种配置方式 1.建立多对多双向关联关系 package cn.happy.entitys; import java.util.HashSet; import java ...

  5. Hibernate (ORM)

    1 框架体系结构 2 hibernate入门 2.1 ORM框架 Hibernate是一个数据持久化层的ORM框架. Object:对象,java对象,此处特指JavaBean Relational: ...

  6. Hibernate(6)—— 一对多 和 多对多关联关系映射(xml和注解)总结

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XM ...

  7. 【Hibernate框架】关联映射(多对多关联映射)

    按着我们的总结行进计划,接下来,就是有关于多对多映射的总结了. 我们来举个例子啊,很长时间以来,房价暴涨不落,但是还有很多人拥有很多套房产,假如说,一个富豪拥有九套房产,家里人么准去住哪一套,我们就以 ...

  8. Hibernate—— 一对多 和 多对多关联关系映射(xml和注解)总结(转载)

    One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XML/Annotation) 懒加载和积极加载 一对多双向外键关联(XML/Annotati ...

  9. ORM和Hibernate的配置方式

    分层体系结构: 逻辑上一般分为三层:表述层(提供与用户交互的界面).业务逻辑层(实现各种业务的逻辑).数据库层(负责存放和管理应用的持久性业务数据). 物理上一般分为两层:物理层(每一层都运行在网络上 ...

随机推荐

  1. 使用while循环+try-except定位元素

    selenium学习过程中,发现自己遇到的最大的困难不是那些元素的操作,而是元素的定位,有时候明明利用firebug将xpath路径确认好了,但是在定位元素的时候还是会报错,后来在度娘上找到了一个方法 ...

  2. Jmeter入门16 数据构造之随机数Random Variable & __Random函数

     接口测试有时参数使用随机数构造.jmeter添加随机数两种方式 1  添加配置 > Random Variable  2  __Random函数   ${__Random(1000,9999) ...

  3. STL容器及算法题:删除奇数的QQ号

    最近思考到这样一个题目:在STL的set和vector容器里存储了1亿个QQ号,编写函数删除奇数QQ号. 1. STL容器简介 首先了解一下 set 和 vector 以及其他类似的 STL 容器: ...

  4. 【[TJOI2017]城市】

    题目 好像\(noip\)之前做某雅礼的题的时候看到过这道题的数据范围增强版 当时那道题数据范围是\(3e5\)感觉神仙的一批 这道题数据范围\(5e3\)那岂不是可以\(O(n^2)\)水过 有一点 ...

  5. 用jquery写的json省市县三级联动下拉

    <form action="#" name="myform"> <label>省</label><select nam ...

  6. 转载 【MySql】Update批量更新与批量更新多条记录的不同值实现方法

    批量更新 mysql更新语句很简单,更新一条数据的某个字段,一般这样写: UPDATE mytable SET myfield = 'value' WHERE other_field = 'other ...

  7. ffmpeg一些filter用法、以及一些功能命令

    来源:http://blog.csdn.net/dancing_night/article/details/46776903 1.加字幕 命令:ffmpeg -i <input> -fil ...

  8. Python学习之路——文件操作

    文件操作分三步:打开文件,读写文件,关闭文件.读取操作时没有给read函数加括号,会出现下面这样的车祸 >>> data = open('/home/supersun/Documen ...

  9. spring(三)-事务管理

    1. Spring事务管理 事务管理:本质是使用spring管理事务,完成数据库对于事务的支持. 事务:一系列对数据库操作的集合,一个操作错误,所有都必须回滚,其特点是acid. (1)事务并发存在问 ...

  10. 菜鸟崛起 DB Chapter 1 数据库概述

    1. 数据库的概述 在目前阶段,如果要存储和管理数据,则离不开数据库.当数据存储到数据库后,就会通过数据库管理系统对这些数据进行组织和管理.数据库由一批数据构成有序的集合,这些数据被存放在结构化的数据 ...