hibernate之多对多映射
源码地址:https://github.com/weiliangchun/JavaCode/tree/master/hibernateImooc/2-1Hibernate-many2many
第一章 多对多的应用场景
案例
企业项目开发过程中
- 一个项目可由多个员工参与开发
- 一个员工可同时参与开发多个项目
多对多关联(many-to-many)
- 多对多关联也是常见的一种关联关系,如项目和员工之间就是典型的多对多关系
- 多对多关联关系一般采用中间表的形式来实现,即新增一张包含关联双方主键的关联表
- 多对多关联可以使用元素和元素进行配置
第二章 多对多的映射配置案例
2-1 创建项目和表
create table project
(
proid int primary key,
proname varchar(20) not null
);
create table employee
(
empid int primary key,
empname varchar(20)
);
create table proemp
(
rproid int,
rempid int
);
alter table proemp add constraint fk_rproid
foreign key (rproid) references project(proid);
alter table proemp add constraint fk_rempid
foreign key (rempid) references employee(empid);
2-2 创建持久化类和映射文件
Project类
public class Project {
private int proid;
private String proname;
// 添加一个员工的集合
private Set<Employee> employees = new HashSet<Employee>();
...
}
Employee类
public class Employee {
private int empid;
private String empname;
// 添加一个项目的集合
private Set<Project> projects = new HashSet<Project>();
...
}
2-3 配置映射文件
Project.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2017-10-12 15:32:10 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
<class name="cc.wlc.entity.Project" table="project">
<id name="proid" column="proid" type="java.lang.Integer">
<generator class="assigned"/>
</id>
<property name="proname" type="java.lang.String">
<column name="proname" length="20" not-null="true"/>
</property>
<!-- 配置多对多关联关系 -->
<set name="employees" table="proemp" cascade="all">
<key column="rproid"></key>
<many-to-many class="cc.wlc.entity.Employee" column="rempid"></many-to-many>
</set>
</class>
</hibernate-mapping>
Employee.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2017-10-12 15:32:10 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
<class name="cc.wlc.entity.Employee" table="employee">
<id name="empid" type="int">
<column name="empid" />
<generator class="assigned" />
</id>
<property name="empname" type="java.lang.String">
<column name="empname" lenght="20" not-null="true"/>
</property>
<set name="projects" table="proemp" inverse="true" lazy="true">
<key>
<column name="rempid" />
</key>
<many-to-many class="cc.wlc.entity.Project" column="rproid"/>
</set>
</class>
</hibernate-mapping>
2-4 测试
package cc.wlc.test;
import org.hibernate.Session;
import org.hibernate.Transaction;
import cc.wlc.entity.Employee;
import cc.wlc.entity.Project;
import cc.wlc.util.HibernateUtil;
/*
* 多对多关联关系的配置
* 同时建立了Project到Employee之间的双向多对多的关系
* 关联关系的维护交由Project方来处理,并且在保存Project对象时会一并保存Employee对象
*/
public class Test {
public static void main(String[] args){
Project project1 = new Project(1001,"项目一");
Project project2 = new Project(1002,"项目二");
Employee employee1 = new Employee(1,"小明");
Employee employee2 = new Employee(2,"小红");
//参加项目一的员工有:小明、小红
project1.getEmployees().add(employee1);
project1.getEmployees().add(employee2);
//参加项目二的员工有:小明
project2.getEmployees().add(employee1);
Session session = HibernateUtil.getSession();
Transaction tx = session.beginTransaction();
session.save(project1);
session.save(project2);
tx.commit();
HibernateUtil.closeSession(session);
}
}
第三章 总结
- 实现多对多关联关系
- 在数据库底层通过添加中间表来指定关联关系
- 在双方的实体中添加一个保存对方的集合
- 在双方的映射文件中使用元素和元素进行关联关系的配置
hibernate之多对多映射的更多相关文章
- Hibernate的多对一映射
一.创建Java工程,新建Lib文件夹,加入Hibernate和数据库(如MySql.Oracle.SqlServer等)的Jar包,创建 hibernate.cfg.xml 文件,并配置,配置项如下 ...
- Hibernate的多对多映射关系
example: 老师(teacher)和学生(Student)就是一个多对多的关系吧?老师可以有多个学生,学生也可以由多个老师,那在Hibernate中多对多是怎样实现的呢?? 在Hibernate ...
- hibernate单向多对一映射
n21: 1.new 两个实体类,一个代表"多"的一端,一个代表"一"的一端. Customer类: public class Customer { priva ...
- hibernate 2 多对多映射
一.实体类 1.Classes.java package cn.gs.wwg.entity; import java.util.Set; public class Classes { private ...
- Hibernate的多对多映射
一.创建Java工程,新建Lib文件夹,加入Hibernate和数据库(如MySql.Oracle.SqlServer等)的Jar包,创建 hibernate.cfg.xml 文件,并配置,配置项如下 ...
- Hibernate(八)多对多映射
一.创建数据表 --学生证表 create table paper ( pid number primary key, pdesc ) , sid number references student( ...
- 【Hibernate框架】关联映射(多对多关联映射)
按着我们的总结行进计划,接下来,就是有关于多对多映射的总结了. 我们来举个例子啊,很长时间以来,房价暴涨不落,但是还有很多人拥有很多套房产,假如说,一个富豪拥有九套房产,家里人么准去住哪一套,我们就以 ...
- 【Hibernate框架】关联映射(一对多,多对一)
根据我们的总结计划,上篇文章我们总结了有关于一对一映射相关知识,接下来,我们进行下一个阶段,一对多.多对一映射相关知识. 场景设定: 国家规定,一个人只能在一个公司上班,一个公司可以拥有很多员工.我们 ...
- hibernate笔记--单(双)向的多对多映射关系
在讲单向的多对多的映射关系的案例时,我们假设我们有两张表,一张角色表Role,一张权限表Function,我们知道一个角色或者说一个用户,可能有多个操作权限,而一种操作权限同时被多个用户所拥有,假如我 ...
随机推荐
- E20170807-mk
literal adj. 照字面的; 原义的; 逐字的; 平实的,避免夸张;
- Rails mysql数据库连接的小坑
基本上直接clone下来的话,数据库连接必失败. 注意,把用户名密码写在.env文件下
- input如何去掉边框
outline: none; border:solid 0px; 两个属性,ok.
- NOI2015 软件包管理器(树链剖分+线段树)
P2146 软件包管理器 题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决 ...
- 像素缓冲区对象PBO 记录
像素缓冲区对象PBO 记录 和所有的缓冲区对象一样,它们都存储在GPU内存中,我们可以访问和填充PBO,方法和其他的缓冲区一样. 当一个PBO被绑定到GL_PIXEL_PACK_BUFFER,任何读取 ...
- BZOJ 2178 Simpson积分
思路: 我发现能用Simpson积分水的题 好像都是裸题诶233333 //By SiriusRen #include <bits/stdc++.h> using namespace s ...
- 大数据~说说Hadoop
Hadoop是一个由Apache基金会所开发的分布式系统基础架构. 用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力进行高速运算和存储. Hadoop实现了一个分布式文件系 ...
- 自动保存草稿 asp+ajax自动存稿功能详解(转自影子)
自动保存草稿功能的原理 我们都知道网页是一种无状态的,每次都需要请求,响应,当一次请求完成后就与服务器断开连接了,所以我们不能像网页一样实现实时的交互功能,但是为了满足更多的需求一个比较无敌的程序员还 ...
- 一、CSS的基础样式
CSS的基础样式 border 边框 复合写法 border:border-width border-style border-color: border-width:边框宽度 top right ...
- 正文处理命令及tar命令
使用cat命令进行文件的纵向合并,具体命令如下所示(注意:>代表将左边命令的执行结果以覆盖的方式放到右边,>>代表将左边命令的执行结果追加到右边) 关于tar命令的一些用法: tar ...