双向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双向一对多对象关系模型映射的更多相关文章

  1. Hibernate双向多对多对象关系模型映射

    1 双向many-to-many 业务模型: 描述员工和项目 一个员工同时可以参与多个项目 一个项目中可以包含多个员工 分析:数据库的数据模型,通过中间关系表,建立两个one-to-many构成man ...

  2. Hibernate单向一对多对象关系模型映射

    1 hibernate 的对象关系映射 Orm: 类-----表 属性------字段 对象------记录 表:在数据库中存在主外键的关系,反向工厂类是由表生成,在由表生成类的时候,类和类之间存在者 ...

  3. Hibernate双向一对一对象关系模型映射

    一个员工一辆车:one-to-one 实现一:让汽车表中的外键唯一 create table emp ( eid int primary key auto_increment, ename varch ...

  4. Hibernate 双向一对多的关联映射

    双向的一对多的关联关系是单项的一对多和单项的多对一的情况下产生的. 1.设计表结构 虽然关联关系变为双向的一对多,但是我们表结构不会发生改变,只是指向变了. 2.创建student对象 3.创建Gra ...

  5. hibernate 双向一对多关系(Annotation mappedBy注解理解)

    1.@mappedBy 属性简单理解为设定为主表(OneToMany方)(这只是我个人理解,上面文章中也有提到过) 所以另一端(ManyToOne)则需要设置外键@JoinColumn(name=&q ...

  6. Hibernate 单项一对多的关联映射

    在上一篇中我们简单介绍了多对一的关联映射,本文介绍hibernate中一对多的关联映射. 1.设计表结构 虽然关联关系由多对一变为一对多,但是我们表结构不会发生改变,只是指向变了. 2.创建stude ...

  7. Mybatis框架中实现双向一对多关系映射

    学习过Hibernate框架的伙伴们很容易就能简单的配置各种映射关系(Hibernate框架的映射关系在我的blogs中也有详细的讲解),但是在Mybatis框架中我们又如何去实现 一对多的关系映射呢 ...

  8. hibernate中一对多关系中的inverse,cascade属性

    举例说明: 一对多关系的两张表:boy.girl(一个男孩可以多个女朋友) boy表结构 Field   Type        ------  -----------  name    varcha ...

  9. Hibernate双向一对多、双向多对多关联关系中的映射文件怎么写

    这里以一对多关联关系为例.以Country类为一端,Competition类为多端. 一个国家可以有多个赛事,但是一个赛事只能属于一个国家. Country类 public class Country ...

随机推荐

  1. jquery获取datagrid多选值

    var checkedItems = $('#dg').datagrid('getChecked'); $.each(checkedItems, function (index, item) { al ...

  2. java练手 公约数和公倍数

    Problem D 公约数和公倍数 时间限制:1000 ms  |  内存限制:65535 KB   描述 小明被一个问题给难住了,现在需要你帮帮忙.问题是:给出两个正整数,求出它们的最大公约数和最小 ...

  3. nyoj 15 括号匹配(二)动态规划

    当时看到(二)就把(一)做了, 一很容易,这道题纠结了好几天,直到今晚才看懂别人的代码谢,勉强才写出来.................... 不愧是难度6的题. #include <stdio ...

  4. import()函数

  5. Aspose.Cells设置自动列宽(最佳列宽)及一些方法总结

    /// <summary> /// 设置表页的列宽度自适应 /// </summary> /// <param name="sheet">wor ...

  6. 通过url地址传递base64加密参数遇到的问题整理

    1. base64的加密解密方法在C#的类库中就有 QueryString中的加号变成了空格问题 Server.UrlEncode(username),获取到的编码又将等于号变成了%3d; 到底改怎么 ...

  7. input注意事项

    一.更改place-holder颜色 input::-webkit-input-placeholder { color: #D6D0CA !important; /* WebKit browsers ...

  8. MATLAB命令大全

    一.常用对象操作:除了一般windows窗口的常用功能键外.1.!dir 可以查看当前工作目录的文件. !dir& 可以在dos状态下查看.2.who 可以查看当前工作空间变量名, whos ...

  9. Markdown入门教程

    Markdown 是一种轻量级的「标记语言」,它的优点很多,目前也被越来越多的写作爱好者,撰稿者广泛使用.看到这里请不要被「标记」.「语言」所迷惑,Markdown 的语法十分简单.常用的标记符号也不 ...

  10. PHP开发神器——phpstorm

    常用快捷键 快捷键 说明 ctrl+j 插入活动代码提示 ctrl+alt+t 当前位置插入环绕代码 alt+insert 生成代码菜单 Shift + Enter 新一行 ctrl+q 查看代码注释 ...