框架之 hibernate之关联关系映射
案例:完成CRM的联系人的保存操作
需求分析
1. 因为客户和联系人是一对多的关系,在有客户的情况下,完成联系人的添加保存操作
技术分析之Hibernate的关联关系映射之一对多映射(重点)
1. JavaWEB中一对多的设计及其建表原则 2. 先导入SQL的建表语句
* 创建数据库:create database hibernate_03; 3. 编写客户和联系人的JavaBean程序(注意一对多的编写规则)
* 客户的JavaBean如下
public class Customer {
private Long cust_id;
private String cust_name;
private Long cust_user_id;
private Long cust_create_id;
private String cust_source;
private String cust_industry;
private String cust_level;
private String cust_linkman;
private String cust_phone;
private String cust_mobile; private Set<Linkman> linkmans = new HashSet<Linkman>(); } * 联系人的JavaBean如下
public class Linkman {
private Long lkm_id;
private String lkm_name;
private String lkm_gender;
private String lkm_phone;
private String lkm_mobile;
private String lkm_email;
private String lkm_qq;
private String lkm_position;
private String lkm_memo; private Customer customer; } 4. 编写客户和联系人的映射配置文件(注意一对多的配置编写)
* 客户的映射配置文件如下
<class name="com.xujingyang.domain.Customer" table="cst_customer">
<id name="cust_id" column="cust_id">
<generator class="native"/>
</id>
<property name="cust_name" column="cust_name"/>
<property name="cust_user_id" column="cust_user_id"/>
<property name="cust_create_id" column="cust_create_id"/>
<property name="cust_source" column="cust_source"/>
<property name="cust_industry" column="cust_industry"/>
<property name="cust_level" column="cust_level"/>
<property name="cust_linkman" column="cust_linkman"/>
<property name="cust_phone" column="cust_phone"/>
<property name="cust_mobile" column="cust_mobile"/> <set name="linkmans">
<key column="lkm_cust_id"/>
<one-to-many class="com.xujingyang.domain.Linkman"/>
</set>
</class> * 联系人的映射配置文件如下
<class name="com.xujingyang.domain.Linkman" table="cst_linkman">
<id name="lkm_id" column="lkm_id">
<generator class="native"/>
</id>
<property name="lkm_name" column="lkm_name"/>
<property name="lkm_gender" column="lkm_gender"/>
<property name="lkm_phone" column="lkm_phone"/>
<property name="lkm_mobile" column="lkm_mobile"/>
<property name="lkm_email" column="lkm_email"/>
<property name="lkm_qq" column="lkm_qq"/>
<property name="lkm_position" column="lkm_position"/>
<property name="lkm_memo" column="lkm_memo"/> <many-to-one name="customer" class="com.xujingyang.domain.Customer" column="lkm_cust_id"/>
</class>
技术分析之保存客户和联系人的数据
1. 进行双向关联进行数据的保存
技术分析之级联保存
1. 测试:如果现在代码只插入其中的一方的数据
* 如果只保存其中的一方的数据,那么程序会抛出异常。
* 如果想完成只保存一方的数据,并且把相关联的数据都保存到数据库中,那么需要配置级联!!
* 级联保存是方向性
2. 级联保存效果
* 级联保存:保存一方同时可以把关联的对象也保存到数据库中!!
* 使用cascade="save-update"
技术分析之级联删除
1. 先来给大家在数据库中演示含有外键的删除客户功能,那么SQL语句是会报出错误的
* 例如:delete from customers where cid = 1;
2. 如果使用Hibernate框架直接删除客户的时候,测试发现是可以删除的
3. 上述的删除是普通的删除,那么也可以使用级联删除,注意:级联删除也是有方向性的!!
* <many-to-one cascade="delete" />
技术分析之级联的取值(cascade的取值)和孤儿删除
1. 需要大家掌握的取值如下
* none -- 不使用级联
* save-update -- 级联保存或更新
* delete -- 级联删除
* delete-orphan -- 孤儿删除.(注意:只能应用在一对多关系)
* all -- 除了delete-orphan的所有情况.(包含save-update delete)
* all-delete-orphan -- 包含了delete-orphan的所有情况.(包含save-update delete delete-orphan)
2. 孤儿删除(孤子删除),只有在一对多的环境下才有孤儿删除
* 在一对多的关系中,可以将一的一方认为是父方.将多的一方认为是子方.孤儿删除:在解除了父子关系的时候.将子方记录就直接删除。
* <many-to-one cascade="delete-orphan" />
技术分析之让某一方放弃外键的维护,为多对多做准备
1. 先测试双方都维护外键的时候,会产生多余的SQL语句。
* 想修改客户和联系人的关系,进行双向关联,双方都会维护外键,会产生多余的SQL语句。
* 产生的原因:session的一级缓存中的快照机制,会让双方都更新数据库,产生了多余的SQL语句。
2. 如果不想产生多余的SQL语句,那么需要一方来放弃外键的维护!
* 在<set>标签上配置一个inverse=”true”.true:放弃.false:不放弃.默认值是false
* <inverse="true">
技术分析之cascade和inverse的区别
1. cascade用来级联操作(保存、修改和删除)
2. inverse用来维护外键的
Hibernate的关联关系映射之多对多映射
技术分析之多对多的建表原则
1. JavaWEB的多对多
技术分析之多对多JavaBean的编写
1. 编写用户和角色的JavaBean
* 用户的JavaBean代码如下
public class User {
private Long user_id;
private String user_code;
private String user_name;
private String user_password;
private String user_state; private Set<Role> roles = new HashSet<Role>();
} * 角色的JavaBean代码如下
public class Role {
private Long role_id;
private String role_name;
private String role_memo; private Set<User> users = new HashSet<User>();
} 2. 用户和角色的映射配置文件如下
* 用户的映射配置文件如下
<class name="com.xujingyang.domain.User" table="sys_user">
<id name="user_id" column="user_id">
<generator class="native"/>
</id>
<property name="user_code" column="user_code"/>
<property name="user_name" column="user_name"/>
<property name="user_password" column="user_password"/>
<property name="user_state" column="user_state"/> <set name="roles" table="sys_user_role">
<key column="user_id"/>
<many-to-many class="com.xujingyang.domain.Role" column="role_id"/>
</set>
</class> * 角色的映射配置文件如下
<class name="com.xujingyang.domain.Role" table="sys_role">
<id name="role_id" column="role_id">
<generator class="native"/>
</id>
<property name="role_name" column="role_name"/>
<property name="role_memo" column="role_memo"/> <set name="users" table="sys_user_role">
<key column="role_id"/>
<many-to-many class="com.xujingyang.domain.User" column="user_id"/>
</set>
</class> 3. 多对多进行双向关联的时候:必须有一方去放弃外键维护权
技术分析之多对多的级联保存
1. 级联保存
* <set cascade="save-update">
级联删除(在多对多中是很少使用的)
1. 级联删除
代码
package com.xujingyang.test ; import org.hibernate.Session ;
import org.hibernate.Transaction ;
import org.junit.Test ;
import com.xujingyang.demo.Customer ;
import com.xujingyang.demo.LinkMan ;
import com.xujingyang.utils.HibernateUtil ; /**
* @author oldmonk
* @date 2017年4月16日
*/
public class TestDemo { /**
* 双向添加
*/
@Test
public void Demo1() {
Session session = HibernateUtil.getThreadLocalSession() ;
Transaction transaction = session.beginTransaction() ; Customer customer = new Customer() ;
customer.setCust_name("小明") ; LinkMan lMan1 = new LinkMan() ;
lMan1.setLkm_name("小小明1") ;
LinkMan lMan2 = new LinkMan() ;
lMan2.setLkm_name("小小明2") ; customer.getLinkmans().add(lMan1) ;
customer.getLinkmans().add(lMan2) ;
lMan1.setCustomer(customer) ;
lMan2.setCustomer(customer) ; session.save(customer) ;
session.save(lMan1) ;
session.save(lMan2) ; transaction.commit() ; } /**
* 级联添加, 客户配置中添加cascade="all"此时还维护外建,会执行两次重复的sql语句 ,
* 添加 inverse="true"时,表明客户表不维护外键,不会重复执行
*/
@Test
public void Demo2() {
Session session = HibernateUtil.getThreadLocalSession() ;
Transaction transaction = session.beginTransaction() ; Customer customer = new Customer() ;
customer.setCust_name("小明") ; LinkMan lMan1 = new LinkMan() ;
lMan1.setLkm_name("小小明1") ;
LinkMan lMan2 = new LinkMan() ;
lMan2.setLkm_name("小小明2") ; customer.getLinkmans().add(lMan1) ;
customer.getLinkmans().add(lMan2) ; session.save(customer) ; transaction.commit() ; } /**
* 普通删除,此时会把关联的外建表的列对应的外建置为null
* 不添加任何的delete
* 删除客户的时候 删除联系人:
* 需要在Customer.hbm.xml中set标签上配置cascade="delete"
* 删除联系人 同时删除 客户:
* 需要在LinkMan.hbm.xml中many-to-one标签上配置cascade="delete"
*/
@Test
public void Demo3() {
Session session = HibernateUtil.getThreadLocalSession() ;
Transaction transaction = session.beginTransaction() ; Customer customer = session.get(Customer.class, 1L) ; session.delete(customer) ; transaction.commit() ;
} /**
* 孤儿删除, <set cascade="delete-orphan" />,跟我解除关系,就把你删了
* 不添加时,只是解除关系,外建置为null
*/
@Test
public void Demo4() {
Session session = HibernateUtil.getThreadLocalSession() ;
Transaction transaction = session.beginTransaction() ; Customer customer = session.get(Customer.class, 1L) ; LinkMan linkMan = session.get(LinkMan.class, 1L) ;
customer.getLinkmans().remove(linkMan) ; transaction.commit() ;
}
}
框架之 hibernate之关联关系映射的更多相关文章
- Hibernate的关联关系映射
技术分析之Hibernate的关联关系映射之一对多映射(重点) 1. JavaWEB中一对多的设计及其建表原则 2. 先导入SQL的建表语句 ...
- Hibernate之关联关系映射(一对一主键映射和一对一外键映射)
1:Hibernate的关联关系映射的一对一外键映射: 1.1:第一首先引包,省略 1.2:第二创建实体类: 这里使用用户信息和身份证信息的关系,用户的主键编号既可以做身份证信息的主键又可以做身份证信 ...
- SSH:Hibernate框架(七种关联关系映射及配置详解)
概念 基本映射是对一个实体进行映射,关联映射就是处理多个实体之间的关系,将关联关系映射到数据库中,所谓的关联关系在对象模型中有一个或多个引用. 分类 关联关系分为上述七种,但是由于相互之间有各种关系, ...
- (转)Hibernate框架基础——一对多关联关系映射
http://blog.csdn.net/yerenyuan_pku/article/details/52746413 上一篇文章Hibernate框架基础——映射集合属性详细讲解的是值类型的集合(即 ...
- (转)Hibernate框架基础——多对多关联关系映射
http://blog.csdn.net/yerenyuan_pku/article/details/52756536 多对多关联关系映射 多对多的实体关系模型也是很常见的,比如学生和课程的关系.一个 ...
- Hibernate之关联关系映射(一对多和多对一映射,多对多映射)
~~~接着之前的Hibernate框架接着学习(上篇面试过后发现真的需要学习一下框架了,不然又被忽悠让去培训.)~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1: ...
- Hibernate 实体关联关系映射【转】
Hibernate关联关系映射目录│ ├─单向关联│ ├─ 一对一外键单向关联│ ├─ 一对一主键单向关联│ ├─ 一对一连接表单向关联│ ├─ 一对多外键单向关联│ ├─ 一对多 ...
- Hibernate 实体关联关系映射----总结
在我看来,Hibernate提供这些映射关系,常用就是一对一和多对一,并且在能不用连接表的时候尽量不要用连接表.多对多会用到,如果用到了,应该首先考虑底层数据库设计是否合理. 在实际开发中,在Hi ...
- Hibernate 实体关联关系映射(转载)
原文链接地址:http://lavasoft.blog.51cto.com/62575/39398/ Hibernate:Hibernate关联关系映射实例速查 Hibernate关联关系映射目录 ...
随机推荐
- 配置SSH密码登录
在客户端生成公钥: ssh-keygen –t rsa 生成的公钥默认位置在~/.ssh/目录 把公钥上传到服务器端: scp id_rsa.pub root@ip地址:文件保存路径 cat id_r ...
- mongodb数据文件结构——record是内嵌BSON的双向链表,多个record或索引组成extent
数据文件结构 Extent 在每一个数据文件内,MongoDB把所存储的BSON文档的数据和B树索引组织到逻辑容器“Extent”里面.如下图所示(my-db.1和my-db.2 是数据库的两个数据文 ...
- Oracle Index Clustering Factor(集群因子)
一.本文说明: 今天在做测试的时候发现字段上有索引,但是执行计划就是不走索引,经过在网上查找才发现原来是索引的集群因子过高导致的.本文属于转载 二.官网说明 The index clustering ...
- SQL1221N The Application Support Layer heap cannot be allocated. SQLSTATE=57011
不能分配“应用程序支持层“堆 内存不足(系统中可用的调页空间量或交换空间量或系统中可用的物理内存量),可能会导致问题,并提示如下错误信息: SQL1221N The Application Supp ...
- Struts2(1)
一.struts概述 1.struts2框架应用在javaee三层结构中web层框架 2.struts2框架在struts1和webwork基础之上发展全新的框架 二.struts2环境搭建 1.导包 ...
- Mybatis_generator自动化生成代码
1.Run as 2.ok
- HttpServletRequest获取请求得URL信息
request对象中包含的是请求信息,当我们在浏览器地址栏上输入:http://localhost:8080/Example/AServlet?username=zhangsan,这段地址也会作为请求 ...
- LeetCode Output Contest Matches
原题链接在这里:https://leetcode.com/problems/output-contest-matches/description/ 题目: During the NBA playoff ...
- Codeforces 808F. Card Game
题目大意 一个物品有三个属性 : 价值,键值,等级. 你不能选取等级高于\(level\)的物品,键值之和为质数的两个数字不共存. 问最低的等级使得可以选出价值之和超过\(k\)的物品. \(n\le ...
- Oracle job procedure 存储过程定时任务(转自hoojo)
Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相关视图 ...