多表操作之多对多关系简介

思路就是:

  • 在数据库底层通过添加中间表来指定关联关系。

  • 在双方的实体中添加一个保存对方的集合

  • 在双方的配置文件中使用set标签和many-to-many标签来进行关联关系的配置。即可完成!

  • 调用Hibernate的相关的API,操作就行了。

需要注意的地方

  • 首先是数据库中表的创建

    这里有一个小例子:
    
    多对多的核心表,第三方表。table:
    create table thrid(
    one_id int not null,
    two_id int not null,
    constranit FK_one_id froeign key(one_id) reference one(id_in_one),
    constraint FK_two_id foreign key(two_id) reference two(id_in_two)
    );
    

    这里就是将两个表的主键作为了这个第三方的外键了。这样可以方便关系的搭建。

  • 然后是创建核心的Hibernate.cfg.cml文件,这里不再过多的阐述。

  • 再就是创建相应的符合数据库中表结构的JavaBean实体类。

    • 遵守JavaBean的命名规范
    • 有无参的构造方法
    • 属性私有,以共有的setter和getter访问
    • 一定一定要记得包含多表中对方的一个集合set。
  • 创建XX.hbm.xml映射文件:

    • 这个映射文件可谓是Hibernate的核心所在了。注意这个文件要放到和实体类一个目录下,也就是放到实体包中,这样会比较好,方便查找和操作。

    • 使用插件生成或者参照模板进行修改。最核心的就是set标签及内部的many-to-many标签了,如下:

      employees 映射文件配置(多)

      <?xml version="1.0"?>
      
      <!DOCTYPE hibernate-mapping PUBLIC
      
              "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
      
              "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
      
          <hibernate-mapping package="cn.itcast.h_hbm_oneToMany">
      
          <class name="Employee" table="employee">
      
             <id name="id">
      
                 <generator class="native"></generator>
      
             </id>
      
             <property name="name"></property>
      
             <!-- department属性,Department类型,表示Employee与Department的多对一 -->
      
             <many-to-one name="department" column="departmentId" class="Department"></many-to-one>
      
          </class>
      
      </hibernate-mapping>
      

    以及 department 映射文件配

        <!DOCTYPE hibernate-mapping PUBLIC
    
            "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    
            "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="cn.itcast.h_hbm_oneToMany">
    
        <class name="Department" table="department">
    
           <id name="id">
    
               <generator class="native"></generator>
    
           </id>
    
           <property name="name"></property>
    
           <!-- employees属性,Set集合,表达的是Department与Employee的一对多
    
               inverse属性:true表示自己是否放弃维护关联关系,默认为false。
    
            -->
    
           <set name="employees" inverse="true">
    
               <key column="departmentId"></key>
    
               <one-to-many class="Employee"/>
    
           </set>
    
        </class>
    
    </hibernate-mapping>
    

总结

配置完以上几步,我们就可以正常的编写我们的“DAO”层代码了,但是由于有了Hibernate的Session这个神器,我们需要做的也就是在DAO层中进行相关的API的调用。这将是非常非常的简单以及轻松的一项任务。

Hibernate之多对多表,操作实例的更多相关文章

  1. Hibernate框架笔记03表操作多对多配置

    目录 1. 数据库表与表之间的关系 1.1 一对多关系 1.2 多对多关系 1.3 一对一关系[了解] 2. Hibernate的一对多关联映射 2.1 创建一个项目,引入相关jar包 2.2. 创建 ...

  2. legend3---lavarel多对多模型操作实例

    legend3---lavarel多对多模型操作实例 一.总结 一句话总结: 在多对多模型中,增加关系表的数据 需要 弄一个和关系表一对多的模型关系 1.在lavarel关系模型中,课程和标签表是多对 ...

  3. (转)Hibernate中的多表操作

    http://blog.csdn.net/yerenyuan_pku/article/details/70556208 Hibernate中的多表操作 在实际开发中,我们不可能只是简简单单地去操作单表 ...

  4. sqlalchemy模块介绍、单表操作、一对多表操作、多对多表操作、flask集成.

    今日内容概要 sqlalchemy介绍和快速使用 单表操作增删查改 一对多 多对多 flask集成 内容详细 1.sqlalchemy介绍和快速使用 # SQLAlchemy是一个基于 Python实 ...

  5. (十二)Hibernate中的多表操作(2):单向多对一

    由“多”方可知“一”方的信息,比如多个员工使用同一栋公寓,员工可以知道公寓的信息,而公寓无法知道员工的信息. 案例一:使用xml配置 pojo类 Group.java package bean; // ...

  6. spring-mybatis-data-common程序级分表操作实例

    spring-mybatis-data-common-2.0新增分表机制,在1.0基础上做了部分调整. 基于机架展示分库应用数据库分表实力创建 create table tb_example_1( i ...

  7. MariaDB数据表操作实例

    1. MariaDB 数据库操作实例 MariaDB>create database class; //创建class数据库 MariaDB>use class; MariaDB>c ...

  8. (十五)Hibernate中的多表操作(5):双向多对多

    Hibernate的双向关联. 对象之间可以相互读取.        双向只针对读取的操作.对于增.删除.改的操作没有任何影响. 案例 : 实现双向多对多 MenuBean.java package ...

  9. (十三)Hibernate中的多表操作(3):单向多对多

    多对多的处理方式是,有一张中间表,中间表保存两个多方之间的关系.首先来看实际应用场景:在之前开发的系统中,应用了基于角色的控制访问,也就是RBAC模型,一个用户可能存在多种角色,一种角色也可能有多个用 ...

随机推荐

  1. Polya计数

    Let it Bead Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5365   Accepted: 3585 Descr ...

  2. bzoj4034[HAOI2015]树上操作 树链剖分+线段树

    4034: [HAOI2015]树上操作 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 6163  Solved: 2025[Submit][Stat ...

  3. 【译】基于主机的卡仿真(Host-based Card Emulation)

    基于主机的卡仿真(Host-based Card Emulation) 能提供NFC功能很多Android手机已经支持NFC卡模拟.在大多数情况下,该卡是由设备中的单独的芯片仿真,所谓的安全元件.由无 ...

  4. POJ-2299 Ultra-QuickSort---树状数组求逆序对+离散化

    题目链接: https://vjudge.net/problem/POJ-2299 题目大意: 本题要求对于给定的无序数组,求出经过最少多少次相邻元素的交换之后,可以使数组从小到大有序. 两个数(a, ...

  5. MySQL使用判断

    1.case语法 在第一个方案的返回结果中, value=compare-value.而第二个方案的返回结果是第一种情况的真实结果.如果没有匹配的结果值,则返回结果为ELSE后的结果,如果没有ELSE ...

  6. springboot解决跨域问题(Cors)

    1.对于前后端分离的项目来说,如果前端项目与后端项目部署在两个不同的域下,那么势必会引起跨域问题的出现. 针对跨域问题,我们可能第一个想到的解决方案就是jsonp,并且以前处理跨域问题我基本也是这么处 ...

  7. nginx的yum安装,基本参数使用,编译参数说明和Nginx基本配置,模块安装

    nginx的yum安装从nginx官网获取源 vim /etc/yum.repose.d/nginx.repo[nginx]name=nginx repobaseurl=http://nginx.or ...

  8. spring cloud 入门系列四:使用Hystrix 实现断路器进行服务容错保护

    在微服务中,我们将系统拆分为很多个服务单元,各单元之间通过服务注册和订阅消费的方式进行相互依赖.但是如果有一些服务出现问题了会怎么样? 比如说有三个服务(ABC),A调用B,B调用C.由于网络延迟或C ...

  9. JavaScript 错误处理 Throw、Try 和 Catch

    try 语句测试代码块的错误. catch 语句处理错误. throw 语句创建自定义错误. JavaScript 错误 当 JavaScript 引擎执行 JavaScript 代码时,会发生各种错 ...

  10. CNN在中文文本分类的应用

    深度学习近一段时间以来在图像处理和NLP任务上都取得了不俗的成绩.通常,图像处理的任务是借助CNN来完成的,其特有的卷积.池化结构能够提取图像中各种不同程度的纹理.结构,并最终结合全连接网络实现信息的 ...