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

本篇博客将讲述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. TCP的建立和关闭

    一.TCP头信息 简单的至少应该知道,源端口,目的端口,序号,确认号,标志位,校验和 二.TCP的建立 1.客户端将SYN标志位置1,同时生成随机的序号,确认号是0. 2.服务器接收到SYN,知道有人 ...

  2. ubuntu16.4安装最新版wine3.0

    1.主体大致过程 $ wget https://dl.winehq.org/wine/source/3.0/wine-3.0.tar.xz $ tar -xvf wine-3.0.tar.xz $ c ...

  3. 【bzoj2563】 阿狸和桃子的游戏

    题目 非常妙的题目,一看到就以为是一道博弈,之后就不会做了 正解非常巧妙,由于我们只需要求出最后两个人得分的差值,所以对于每一条边我们将其的权值拆成两边,分给其连接的两个点 如果这两个点被同一个人选择 ...

  4. 搭建 webpack + React 开发环境

    说在开头 上个月断断续续的在研究webpack的配置,但是很多网上的文章基本上都是只说了开发环境的配置,而忽略了生产环境的配置.大致研究了一下门路,然后就来写一篇随笔让自己能在以后能有个地方可以做参考 ...

  5. 关于eclipse中引入项目报错或者没有JRE System Library问题(jre报错)或者jre1.7(8)改为jre1.8(7)等问题

    解决方法: 右键项目工程-->>properties->>java bulid path -->>>libraries -->>add libra ...

  6. js实现div滚动条在页面刷新 滚动条位置固定

    思想:1.通过div的onscroll事件记录滚动条的scrollTop值,设置到document.cookie 2.页面加载时再读取document.cookie的值,设置给div的scrollTo ...

  7. C#位数不足补零

    C#位数不足补零:int i=10;方法1:Console.WriteLine(i.ToString("D5"));方法2:Console.WriteLine(i.ToString ...

  8. MVC5 Attribute(特性)

    AuthorizeAttribute:一般用来判断权限 ActionFilterAttribute:方法执行前后动作 OutputCacheAttribute:输出缓存设置 注:我们创建名称的时候请带 ...

  9. input上传图片并显示

    html: <div id="click"><img> </div><!--照片预览的div --> <div class=& ...

  10. js动画之requestAnimationFrame

    1.setTimeout和setInterval 在讲setTimeout和setInterval之前,先讲一下异步执行的运行机制.(同步执行也是如此,因为它可以被视为没有异步任务的异步执行.) (1 ...