• Hibernate的一对多关联映射

  • Hibernate的多对多关联映射

数据库表与表之间的关系:一对多,多对多,一对一

一对多:一个部门对应多个员工,一个员工只能属于一个部门。一个客户对应多个联系人,一个联系人只能属于一个客户

一对多建表:在多的一方创建外键。

多对多:一个学生可以选择多门课程,一门课程可以被多个学生选择。一个用户可以选择多个角色,一个角色可以被多个用户选择。

多对多建表:创建中间表。中间表至少有两个字段分别作为外键指向多对多双方的主键。

一对一(了解):

一般可以建成一张表。

一个公司只能有一个注册地址,一个注册地址只能被一个公司注册。

建表原则:

唯一外键对应,外键加约束unique来保证一对一

主键对应

表关系配置:

一对多关系的配置:多的一方放一的一方的对象,一的一方放多的一方的集合,双向配置,可以双向查询。

表架构:

实体类配置:

映射文件配置:

多的一方:

一的一方:

 测试:

Hibernate一对多相关操作:

一对多的级联操作:

级联:是否会同时操作其关联的对象。级联室友方向性的,操作一的一方的时候是否会操作多的一方;操作多的一方是否会操作一的一方

级联保存更新

保存客户级联联系人,操作的主体是客户,需要在Customer.hbm.xml中进行配置

保存联系人级联客户

级联保存或更新:保存联系人级联客户,操作的主体是联系人,需要在LinkMan.hbm.xml中进行配置

测试对象导航:

级联删除:

删除一方,将另一方的数据也一并删除

删除客户级联删除联系人:没有设置级联删除,默认情况:Hibernate修改了联系人的外键,使其为null,然后删除客户

修改设置,删除客户就删除联系人:

删除联系人级联删除客户(基本不用)

将2号联系人原来是1号客户,现在划给2号客户:

双向关联产生多余的SQL语句(客户和联系人的配置里都设置了外键(coloum="lkm_cust_id")),都能维护外键。

解决办法:一的一方放弃外键维护权。关系维护方由多的一方管理。

区分Inverse和Cascade

Hibernate多对多关系配置:

其实可以使用两个一对多,利用中间表模拟多对多的关系

多对多建立双向关系时,因为两个字段都能插入中间表,造成重复,让被动方放弃外键维护权。

建表:用户角色和中间表

配置:

domain:

hbm:

基本操作测试:

多对多级联操作:

级联保存:先让被级联的一方放弃维护权

    @Test
/**
* 多对多级联保存,保存用户级联保存角色
*/
public void demo2(){ //创建2用户3角色
Session session = HibernateUtils.getCurrentSession();
Transaction transaction = session.beginTransaction(); User user1 = new User();
user1.setUser_name("脑袋1");
Role role1 = new Role();
role1.setRole_name("研发部"); //设置双向关联关系
user1.getRoles().add(role1); //保存操作:多对多建立双向关系,一方放弃关系。因为两个字段都能插入中间表造成重复,被动方放弃外键维护权
session.save(user1);
transaction.commit();
}
@Test
/**
* 多对多级联保存,保存角色级联用户
*/
public void demo3(){ //创建2用户3角色
Session session = HibernateUtils.getCurrentSession();
Transaction transaction = session.beginTransaction(); User user1 = new User();
user1.setUser_name("脑袋3");
Role role1 = new Role();
role1.setRole_name("研发部"); //设置双向关联关系
user1.getRoles().add(role1);
role1.getUsers().add(user1); //保存操作:多对多建立双向关系,一方放弃关系。因为两个字段都能插入中间表造成重复,被动方放弃外键维护权
session.save(role1);
transaction.commit();
}

级联删除(基本不用):

删除用户级联删除角色,配置用户cascade:delete

多对多其他操作:

  • 给用户选择角色
  • 给用户改选角色
  • 给用户删除角色

六 Hibernate多表操作&级联&外键维护的更多相关文章

  1. mysql之字段的修改,添加、删除,多表关系(外键),单表详细操作(增删改)

    字段的修改.添加和删除 create table tf1( id int primary key auto_increment, x int, y int ); #修改 alter table tf1 ...

  2. Django学习——Django测试环境搭建、单表查询关键字、神奇的双下划线查询(范围查询)、图书管理系统表设计、外键字段操作、跨表查询理论、基于对象的跨表查询、基于双下划线的跨表查询

    Django测试环境搭建 ps: 1.pycharm连接数据库都需要提前下载对应的驱动 2.自带的sqlite3对日期格式数据不敏感 如果后续业务需要使用日期辅助筛选数据那么不推荐使用sqlite3 ...

  3. hibernate多表操作

    一.表之间的关系 1.一对一 2.一对多 3.多对多 二.表之间关系建表原则 1.一对多:在多的一方创建一个外键,指向一的一方的主键 2.多对多:创建一个中间表,中间表至少有两个字段,分别作为外键指向 ...

  4. Oracle表中添加外键约束

    添加主键约束: ALTER TABLE GA_AIRLINE ADD CONSTRAINT PK_AIRLINE_ID PRIMARY KEY(AIRLINE_ID); 有三种形式的外键约束: 1.普 ...

  5. 在PowerDesigner中设计物理模型1——表和主外键

    原文:在PowerDesigner中设计物理模型1--表和主外键 在PD中建立物理模型由以下几种办法: 直接新建物理模型. 设计好概念模型,然后由概念模型生成物理模型. 设计好逻辑模型,然后由逻辑模型 ...

  6. SQL-46 在audit表上创建外键约束,其emp_no对应employees_test表的主键id。

    题目描述 在audit表上创建外键约束,其emp_no对应employees_test表的主键id.CREATE TABLE employees_test(ID INT PRIMARY KEY NOT ...

  7. SQL SERVER中获取表间主外键关系

    sql server 2008中的主外键关系获取方式: 转自:http://www.cnblogs.com/ke10/archive/2012/06/11/2544655.html SELECT OB ...

  8. 在PowerDesigner中设计物理模型1——表和主外键(转)

    出处:http://www.cnblogs.com/studyzy/archive/2009/12/15/1624899.html 在PD中建立物理模型由以下几种办法: 直接新建物理模型. 设计好概念 ...

  9. Python3-sqlalchemy-orm 联表查询-无外键关系

    #-*-coding:utf-8-*- #__author__ = "logan.xu" import sqlalchemy from sqlalchemy import crea ...

随机推荐

  1. java课极限测试

    在临近国庆的9月30号补课日 碰到了惨绝人寰的java课极限测试 我从下午两点半做到晚上九点 不得不说人在烦躁的时候是真的没办法写代码的 根本不想思考也不想学习.最后的几个小时基本就是在叹息和坐着.也 ...

  2. Web性能测试工具推荐

    WEB性能测试工具主要分为三种: 一种是测试页面资源加载速度的: 一种是测试页面加载完毕后页面呈现.JS操作速度的: 一种是总体上对页面进行评价分析. ~~~如果谁有更好的工具也请一起分享下   1. ...

  3. Python 基础之面向对象之异常处理

    一.认识异常 1.常用异常报错的错误类型 IndexError                索引超出序列的范围 KeyError                  字典中查找一个不存在的关键字 Na ...

  4. kafka2x-Elasticsearch 数据同步工具demo

    Bboss is a good elasticsearch Java rest client. It operates and accesses elasticsearch in a way simi ...

  5. 剑指offer第二版速查表

    3.数组中重复数字:每个位置放置数字与下标对应相等 O(n) 4.二维数组中的查找:右下角开始比较 O(m+n) 5.替换空格:python直接替换 6.从尾到头打印链表: 借助栈或直接利用系统调用栈 ...

  6. JAVA高级编程数据源datasource

    原文链接 数据源 通过jdbc连接数据库,多建立几条连接放在数据源里面.可以设置数据源的最大连接数,同时活跃的连接数,最少空闲的连接数,能够同时接收处理的连接数等等. dbcp数据源 需要的jar包: ...

  7. LUA拾翠

    一.函数 1.格式 optional_function_scope function function_name( argument1, argument2, argument3..., argume ...

  8. RedHat OpenShift QuickStart 1.2

    一.在容器中传入/出文件 1. 创建一个初始化项目 oc login -u developer -p developer oc new-project myproject 2. 在容器中下载文件 先通 ...

  9. 【转载】Cmd Markdown 公式指导手册

    目录 Cmd Markdown 公式指导手册 一.公式使用参考 1.如何插入公式 2.如何输入上下标 3.如何输入括号和分隔符 4.如何输入分数 5.如何输入开方 6.如何输入省略号 7.如何输入矢量 ...

  10. Controller 层类

    package com.thinkgem.jeesite.modules.yudengji.web; import java.util.Date; import javax.servlet.http. ...