Hibernate双向一对多对象关系模型映射
双向one-to-many
描述部门和岗位:一个部门有多个岗位
将单向的one-to-many 和many-to-one合并。
4.1双向的one-to-many数据库模型
create table department
(
did int,
dname varchar
);
create table work
(
id int,
pname varchar,
did int,
constraint fk_did foreign key(did) references department(did)
);
数据库中部门表和员工表构成主外键关系。

4.2产生java中的数据模型

4.3双向one-to-many配置

4.4进行curd操作
4.4.1添加部门信息
/**
* 增加部门信息
* ***/
@Test
public void addDept()
{
//获得Session对象
Session session=sf.openSession();
//开启事务
Transaction tr = session.beginTransaction();
//创建部门对象
Dept dept = new Dept();
dept.setDname("研发部");
session.save(dept);
//提交事务
tr.commit();
//释放资源
session.close();
}
4.4.2新增部门和岗位
/**
* 增加部门信息和岗位信息
* 只在双向映射进行inverse的配置
* inverse:表示双方由谁维护两者之间的关系
* 默认:false 不反转,自己维护
* true:表示控制权的反转(交出),由对方进行维护
*
* one-to-many:处理交给many的一方进行关系的控制。
*
* ***/
@Test
public void addDeptPost()
{
//获得Session对象
Session session=sf.openSession();
//开启事务
Transaction tr = session.beginTransaction();
//创建部门对象
Dept dept = new Dept();
dept.setDname("安慰部22");
//创建岗位对象
Post p=new Post();
p.setPname("逗你玩22");
//实现了岗位的级联保存
dept.getPosts().add(p);
//如果关系进行反转,由岗位进行了控制,建立关系
p.setDept(dept);
session.save(dept);
//提交事务
tr.commit();
//释放资源
session.close();
}
4.4.3删除部门信息
/**
只删除岗位信息,不删除部门信息
****/
@Test
public void deleteDept2()
{
//获得Session对象
Session session=sf.openSession();
//开启事务
Transaction tr = session.beginTransaction();
//查询部门对象
Dept dept = (Dept) session.get(Dept.class, 8);
//创建岗位对象
Post p=new Post();
p.setPid(5);
/**
* 删除与dept解除关系的post对象
* ***/
//解除该部门下某个岗位和部门的关系
dept.getPosts().remove(p);
//提交事务
tr.commit();
//释放资源
session.close();
}
Hibernate双向一对多对象关系模型映射的更多相关文章
- Hibernate双向多对多对象关系模型映射
1 双向many-to-many 业务模型: 描述员工和项目 一个员工同时可以参与多个项目 一个项目中可以包含多个员工 分析:数据库的数据模型,通过中间关系表,建立两个one-to-many构成man ...
- Hibernate单向一对多对象关系模型映射
1 hibernate 的对象关系映射 Orm: 类-----表 属性------字段 对象------记录 表:在数据库中存在主外键的关系,反向工厂类是由表生成,在由表生成类的时候,类和类之间存在者 ...
- Hibernate双向一对一对象关系模型映射
一个员工一辆车:one-to-one 实现一:让汽车表中的外键唯一 create table emp ( eid int primary key auto_increment, ename varch ...
- Hibernate 双向一对多的关联映射
双向的一对多的关联关系是单项的一对多和单项的多对一的情况下产生的. 1.设计表结构 虽然关联关系变为双向的一对多,但是我们表结构不会发生改变,只是指向变了. 2.创建student对象 3.创建Gra ...
- hibernate 双向一对多关系(Annotation mappedBy注解理解)
1.@mappedBy 属性简单理解为设定为主表(OneToMany方)(这只是我个人理解,上面文章中也有提到过) 所以另一端(ManyToOne)则需要设置外键@JoinColumn(name=&q ...
- Hibernate 单项一对多的关联映射
在上一篇中我们简单介绍了多对一的关联映射,本文介绍hibernate中一对多的关联映射. 1.设计表结构 虽然关联关系由多对一变为一对多,但是我们表结构不会发生改变,只是指向变了. 2.创建stude ...
- Mybatis框架中实现双向一对多关系映射
学习过Hibernate框架的伙伴们很容易就能简单的配置各种映射关系(Hibernate框架的映射关系在我的blogs中也有详细的讲解),但是在Mybatis框架中我们又如何去实现 一对多的关系映射呢 ...
- hibernate中一对多关系中的inverse,cascade属性
举例说明: 一对多关系的两张表:boy.girl(一个男孩可以多个女朋友) boy表结构 Field Type ------ ----------- name varcha ...
- Hibernate双向一对多、双向多对多关联关系中的映射文件怎么写
这里以一对多关联关系为例.以Country类为一端,Competition类为多端. 一个国家可以有多个赛事,但是一个赛事只能属于一个国家. Country类 public class Country ...
随机推荐
- 只会CSS还不够,LESS、SASS、BootStrap、Foundation一网打尽!
有些人想学CSS,不知如何下手:有些人已经学会CSS的各种属性,却不知如何运用:有些人会平面设计,不知道如何与网页设计结合:有些人会HTML,就是学不会CSS.试问自己,图中的技术你都会了吗? 别总是 ...
- PHP基础 mysqli的事务处理
1: <?php 2: // PHP 的mysqli的事务处理 3: //======================================================== 4: ...
- POJ 2155 Matrix
二维树状数组.... Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissio ...
- ThinkPHP 修改,删除数据,全部显示
1,修改数据 //数据修改 function Update() { $model = D("info"); /* //1,数组方式 $attr = array( "Cod ...
- 微信公众平台中添加qq在线聊天代码
微信公众平台是个不错的媒体,可以和你的小伙伴们即时交流,但你的小伙伴们是用手机上的微信,打字自然就慢了:有人说用微信网页版,那个也不习惯,再说也不一定所有人都知道网页版微信.(2014.01.22更新 ...
- cf558c(bfs)
C. Amr and Chemistry time limit per test 1 second memory limit per test 256 megabytes input standard ...
- android service被系统回收的解决方法
自己的app的service总是容易被系统回收,搜罗了一下,基本上的解决思路有以下几种: 1.把service写成系统服务,将永远不会被回收(未实践): 在Manifest.xml文件中设置persi ...
- BZOJ3083——遥远的国度
1.题目大意:三个操作,换根,修改树上的某条路径,查询一个子树的最小值 2.分析:这个其实还是挺好做的,修改树上的某条路径,裸树剖,查询子树的最小值,这个是树剖满足dfs序 那么就是换根了,对吧,其实 ...
- Yii2.0中文开发向导——控制器(Controller)
控制器(Controller) 本节包含以下方面的内容 基本概念 路由 默认路由 动作的参数 在动作中定义参数 从请求(request)中获取参数 独立动作 动作过滤器(Action Filters) ...
- linux kernel input 子系统分析
Linux 内核为了处理各种不同类型的的输入设备 , 比如说鼠标 , 键盘 , 操纵杆 , 触摸屏 , 设计并实现了一个对上层应用统一的试图的抽象层 , 即是Linux 输入子系统 . 输入子系统的层 ...