源码地址: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);
    }
}

第三章 总结

  • 实现多对多关联关系
  • 在数据库底层通过添加中间表来指定关联关系
  1. 在双方的实体中添加一个保存对方的集合
  2. 在双方的映射文件中使用元素和元素进行关联关系的配置

hibernate之多对多映射的更多相关文章

  1. Hibernate的多对一映射

    一.创建Java工程,新建Lib文件夹,加入Hibernate和数据库(如MySql.Oracle.SqlServer等)的Jar包,创建 hibernate.cfg.xml 文件,并配置,配置项如下 ...

  2. Hibernate的多对多映射关系

    example: 老师(teacher)和学生(Student)就是一个多对多的关系吧?老师可以有多个学生,学生也可以由多个老师,那在Hibernate中多对多是怎样实现的呢?? 在Hibernate ...

  3. hibernate单向多对一映射

    n21: 1.new 两个实体类,一个代表"多"的一端,一个代表"一"的一端. Customer类: public class Customer { priva ...

  4. hibernate 2 多对多映射

    一.实体类 1.Classes.java package cn.gs.wwg.entity; import java.util.Set; public class Classes { private ...

  5. Hibernate的多对多映射

    一.创建Java工程,新建Lib文件夹,加入Hibernate和数据库(如MySql.Oracle.SqlServer等)的Jar包,创建 hibernate.cfg.xml 文件,并配置,配置项如下 ...

  6. Hibernate(八)多对多映射

    一.创建数据表 --学生证表 create table paper ( pid number primary key, pdesc ) , sid number references student( ...

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

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

  8. 【Hibernate框架】关联映射(一对多,多对一)

    根据我们的总结计划,上篇文章我们总结了有关于一对一映射相关知识,接下来,我们进行下一个阶段,一对多.多对一映射相关知识. 场景设定: 国家规定,一个人只能在一个公司上班,一个公司可以拥有很多员工.我们 ...

  9. hibernate笔记--单(双)向的多对多映射关系

    在讲单向的多对多的映射关系的案例时,我们假设我们有两张表,一张角色表Role,一张权限表Function,我们知道一个角色或者说一个用户,可能有多个操作权限,而一种操作权限同时被多个用户所拥有,假如我 ...

随机推荐

  1. E20170919-hm

    infinity   n. <数>无穷大; 无限的时间或空间;

  2. C. Unusual Product(cf)

    http://codeforces.com/problemset/problem/405/C 题意: 给出一个n*n的矩阵,有q个操作,输入3时,输出A ,A等于第i行乘以第i列的对应元素的和(mod ...

  3. String,StringBuffer和StringBuilder

    在执行速度方面的比较:StringBuilder > StringBuffer StringBuffer与StringBuilder,他们是字符串变量,是可改变的对象,每当我们用它们对字符串做操 ...

  4. DataFrame编程模型初谈与Spark SQL

    Spark SQL在Spark内核基础上提供了对结构化数据的处理,在Spark1.3版本中,Spark SQL不仅可以作为分布式的SQL查询引擎,还引入了新的DataFrame编程模型. 在Spark ...

  5. Ambari?自动部署Hadoop集群

    自动部署?Ambari Ambari 跟 Hadoop 等开源软件一样,也是 Apache Software Foundation 中的一个项目,并且是顶级项目.就 Ambari 的作用来说,就是创建 ...

  6. jQuery五屏轮播手风琴切换代码

    jQuery五屏轮播手风琴切换代码 在线演示本地下载

  7. Redux 基础概念

    Redux is a predictable state container for JavaScript apps.,亦即 Redux 希望能提供一个可以预测的 state 管理容器,让开发者可以可 ...

  8. android中textview单行显示,多余的省略

    <TextView android:id="@+id/music_title" android:layout_width="wrap_content" a ...

  9. H5 标签属性、input属性

    高亮文字: 全部商品只要<mark>6.18</mark> 结果:     加拼音文字: <ruby>變<rt>bian</rt></ ...

  10. html——细线表格

    细线: 1.table表格设置背景色 2.table中设置单元格距离 3.tr标签设置另外一种背景色 <!DOCTYPE html> <html> <head lang= ...