啊讲道理放假这十天不到啊

感觉生活中充满了绝望 这就又开学了

好吧好吧继续学习笔记?还是什么的

一对一关联映射

这次我们仍然准备了两个表

一个是用户表Users

一个是档案表Resume

他们的关系是一对一(一个用户只能有一份档案 一份档案只能属于一个永固)

我们无需建表,Hibernate会检查数据库中有没有对应的表,如果没有,自动生成

我们也可以用来看自动生成的表是什么样子的

一对一外键映射FK

那么接下来是小配置文件

user的小配置文件

<one-to-one name="resume" class="Resume" property-ref="user"></one-to-one>

name属性是小配置关联的实体类中 存放的另一个实体的对象的名称

Class当然是一对一关系中对应的实体类

那么Users这个实体类结构如下

property-ref 改变有关联关系对象的列的等值对比
默认:A表主键默认关联B表主键
设置后是让A表的主键关联B表的非主键列

resume的小配置文件

<many-to-one name="users" class="Users" columm="uid" unique="true" cascade="all"></many-to-one>

column 关联的主键列(相当于档案表是外检表,用户表是主表)

unique 唯一的 保证了一对一的关系

Resume实体类如下

编写测试类。

@Before
public void before() {
session = HibernateUtil.currentSession();
tx = session.beginTransaction();
} @After
public void after() {
tx.commit();
HibernateUtil.closeSession();
} @Test
public void insert() {
Resume resume = new Resume();
resume.setResname("斯沃的机密档案"); Users user = new Users();
user.setUname("斯沃"); resume.setUser(user);
user.setResume(resume); session.save(resume);
}

运行成功后我们来看看自动生成的表的结构

User用户表里只有我们的编号和姓名两列

而在档案表里除了编号和档案名称

  还多出了一列 用户id

一对一外键映射相当于一个一对多的关联映射,但是加上了一个唯一约束使得一个User只能对应一个档案

(否则多个档案的Userid列会可以指向同一个User)

一对一主键映射PK

然后呢是一对一主键映射

我比较懒 因为已经提前知道一对一外键映射和逐渐映射

自动生成的表的表结构是不一样的

可是我比较不想举一个新的例子 所以仍用用户和档案的例子

为了避免重复,我们在小配置中让他们关联的表名变化

这次是Users2表和Resume2表(虽然实体类的名称没有变)

那么实体类是没有变化的

我们直接来看小配置

先看档案的

<one-to-one name="user" class="Users" cascade="all"></one-to-one>

没有什么可以说的样子

看Users用户的

哦对了在这里突然想到 为什么用户表叫Users而不是User 关键字的问题

<one-to-one name="resume" class="Resume" constrained="true"></one-to-one>

constrained 约束用户表中出现的档案列必须在主表档案表中出现过

另外一点 就是Users表的主键生成策略

<id name="userid" type="java.lang.Integer">
<!--主键生成策略-->
<generator class="foreign">
<param name="property">resume</param>
</generator>
</id>

这里使用的主键生成策略是foreign 关联到的是表RESUME

也就是两个表的对应的记录的主键会相同

所以在查询的时候只需要查询一个主键就可以把它们关联起来

测试类的代码如下

@Before
public void before() {
session = HibernateUtil.currentSession();
tx = session.beginTransaction();
} @After
public void after() {
tx.commit();
HibernateUtil.closeSession();
} @Test
public void insert() {
Resume resume = new Resume();
resume.setResname("斯沃的机密档案"); Users user = new Users();
user.setUname("斯沃"); resume.setUser(user);
user.setResume(resume); session.save(user);
}

等等 为啥感觉区别不大= =

不要在意细节 看看结果是怎么样的

果然如我所说= =

组件映射

那么接下来是组件映射

组件映射就是两个实体类 一对一的关系

或者说其实一个实体类是另一个实体类的扩展

我们举的例子是一个 People 人 和一个PeopleInfo 人的信息

其中人保存的是人的编号pid 名字pname 和 对应的人的信息这个实体类

我们看一下两个实体类

噢我们只需要一个小配置文件 就是People的小配置文件

那么需要怎么写。。。

 <class name="People" table="PEOPLE">
<id name="pid" type="java.lang.Integer">
<!--主键生成策略-->
<generator class="native"/>
</id>
<property name="pname" type="string"/> <component name="info" class="PeopleInfo">
<parent name="people"/>
<property name="address"></property>
<property name="phone"></property>
</component>
</class>

在class节点中

使用一个component节点 关联着另一个类

然后 就 可以使用 了

@Test
public void insert() {
People people=new People();
people.setPname("天命"); PeopleInfo info=new PeopleInfo();
info.setAddress("北京");
info.setPhone("15201520190"); people.setInfo(info);
info.setPeople(people);
session.save(people);
}

最后我们看看运行后生成的表

果然是只有一个表的 表中的列是People和PeopleInfo两个实体类中的集合

【学习笔记】Hibernate 一对一关联映射 组件映射 二级缓存 集合缓存的更多相关文章

  1. Hibernate第九篇【组件映射、继承映射】

    前言 到目前位置,我们已经学习了一对一.一对多.多对一.多对多映射了-既然Hibernate是ORM实现的框架,它还提供了组件映射和继承映射..本博文主要讲解组件映射和继承映射 Java主要的类主要有 ...

  2. mybatis学习笔记(10)-一对一查询

    mybatis学习笔记(10)-一对一查询 标签: mybatis mybatis学习笔记10-一对一查询 resultType实现 resultMap实现 resultType和resultMap实 ...

  3. SQL反模式学习笔记7 多态关联

    目标:引用多个父表 反模式:使用多用途外键.这种设计也叫做多态关联,或者杂乱关联. 多态关联和EAV有着相似的特征:元数据对象的名字是存储在字符串中的. 在多态关联中,父表的名字是存储在Issue_T ...

  4. Flutter学习笔记(10)--容器组件、图片组件

    如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...

  5. Flutter学习笔记(11)--文本组件、图标及按钮组件

    如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 文本组件 文本组件(text)负责显示文本和定义显示样式,下表为text常见属性 Text组件属性及描述 属性名 类型 默认 ...

  6. Flutter学习笔记(12)--列表组件

    如需转载,请注明出处:Flutter学习笔记(12)--列表组件 在日常的产品项目需求中,经常会有列表展示类的需求,在Android中常用的做法是收集数据源,然后创建列表适配器Adapter,将数据源 ...

  7. Hibernate中一对一关联映射/组件映射

    Hibernate映射:一对一关联 1.按照外键映射 2.按照主键映射 组件映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这两种 映射方式分别 ...

  8. Hibernate中的一对一关联和组件的映射

    Hibernate提供了两种映射一对一映射关联关系的方式: 01.按照外键映射 02.按照主键映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这 ...

  9. Hibernate 一对一关联映射,mappedBy参数解析

    在最近java,SSH框架的学习中遇到了这样的一个问题,在Hibernate的开发中一对一关联映射的单向关联,主表会在次表新增一列次表的主键如下图,但是在双向关联中次表不会在表中创建主表的主键一列,这 ...

随机推荐

  1. linux 硬软链接区别

    linux 硬软链接区别 linux的软连接(symbolic link or soft link)类似于windows的快捷方式:而硬链接(hard link)机制有点像copy,不过不同的是,带有 ...

  2. 深入剖析Java编程中的中文问题及建议最优解决方法

    摘录自:http://fafeng.blogbus.com/logs/3062998.html http://www.blogbus.com/fafeng-logs/3063006.html 深入剖析 ...

  3. ASP.NET Core Razor页面禁用防伪令牌验证

    在这篇短文中,我将向您介绍如何ASP.NET Core Razor页面中禁用防伪令牌验证. Razor页面是ASP.NET Core 2.0中增加的一个页面控制器框架,用于构建动态的.数据驱动的网站: ...

  4. vue 的准备项目架构环境配置

    一.环境搭建 中国镜像 composer config repo.packagist composer https://packagist.phpcomposer.com 命令 composer in ...

  5. MySQLdb 部署

    1.windows 下载后,直接安装即可 http://www.jb51.net/softs/73369.html#download 双击安装 MySQL-python-1.2.3.win32-py2 ...

  6. RocketMQ-广播模式消费

    Rocketmq 消费者默认是集群的方式消费的,消费者还可以用广播的模式进行消费.广播模式消费就是所有订阅同一个主题的消费者都会收到消息.代码实现上其实很简单,就是在消费端添加 consumer.se ...

  7. spring boot 文件上传 文件过大 FileUploadBase$SizeLimitExceed

    application.properties中加入 multipart.maxFileSizemultipart.maxRequestSize Spring Boot 1.3.x或者之前 multip ...

  8. impala集成sentry

    1.安装配置sentry 详细步骤见上一篇安装配置sentry. 2.配置impala 注:以下配置未集成kerberos安全认证 在/etc/imapla/conf目录下创建sentry-site. ...

  9. laravel5.5 when()的用法

    当你在使用where语句有前提条件时,比如某值为1的时候才执行where子句,否则不执行,这个时候,laravel5.5新出了一个简便方法when($arg,fun1[,fun2]). 具体用法如下: ...

  10. 使用copy命令合并二进制文件

    CMD下的copy命令可以将一份或多份文件复制到另一个位置. 也具备连接文件的功能. 使用如下命令格式可以将多个二进制文件合并为一个二进制文件: copy  /b  file1+file2+...+f ...