【学习笔记】Hibernate 一对一关联映射 组件映射 二级缓存 集合缓存
啊讲道理放假这十天不到啊
感觉生活中充满了绝望 这就又开学了
好吧好吧继续学习笔记?还是什么的
一对一关联映射
这次我们仍然准备了两个表
一个是用户表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 一对一关联映射 组件映射 二级缓存 集合缓存的更多相关文章
- Hibernate第九篇【组件映射、继承映射】
前言 到目前位置,我们已经学习了一对一.一对多.多对一.多对多映射了-既然Hibernate是ORM实现的框架,它还提供了组件映射和继承映射..本博文主要讲解组件映射和继承映射 Java主要的类主要有 ...
- mybatis学习笔记(10)-一对一查询
mybatis学习笔记(10)-一对一查询 标签: mybatis mybatis学习笔记10-一对一查询 resultType实现 resultMap实现 resultType和resultMap实 ...
- SQL反模式学习笔记7 多态关联
目标:引用多个父表 反模式:使用多用途外键.这种设计也叫做多态关联,或者杂乱关联. 多态关联和EAV有着相似的特征:元数据对象的名字是存储在字符串中的. 在多态关联中,父表的名字是存储在Issue_T ...
- Flutter学习笔记(10)--容器组件、图片组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...
- Flutter学习笔记(11)--文本组件、图标及按钮组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 文本组件 文本组件(text)负责显示文本和定义显示样式,下表为text常见属性 Text组件属性及描述 属性名 类型 默认 ...
- Flutter学习笔记(12)--列表组件
如需转载,请注明出处:Flutter学习笔记(12)--列表组件 在日常的产品项目需求中,经常会有列表展示类的需求,在Android中常用的做法是收集数据源,然后创建列表适配器Adapter,将数据源 ...
- Hibernate中一对一关联映射/组件映射
Hibernate映射:一对一关联 1.按照外键映射 2.按照主键映射 组件映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这两种 映射方式分别 ...
- Hibernate中的一对一关联和组件的映射
Hibernate提供了两种映射一对一映射关联关系的方式: 01.按照外键映射 02.按照主键映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这 ...
- Hibernate 一对一关联映射,mappedBy参数解析
在最近java,SSH框架的学习中遇到了这样的一个问题,在Hibernate的开发中一对一关联映射的单向关联,主表会在次表新增一列次表的主键如下图,但是在双向关联中次表不会在表中创建主表的主键一列,这 ...
随机推荐
- linux 硬软链接区别
linux 硬软链接区别 linux的软连接(symbolic link or soft link)类似于windows的快捷方式:而硬链接(hard link)机制有点像copy,不过不同的是,带有 ...
- 深入剖析Java编程中的中文问题及建议最优解决方法
摘录自:http://fafeng.blogbus.com/logs/3062998.html http://www.blogbus.com/fafeng-logs/3063006.html 深入剖析 ...
- ASP.NET Core Razor页面禁用防伪令牌验证
在这篇短文中,我将向您介绍如何ASP.NET Core Razor页面中禁用防伪令牌验证. Razor页面是ASP.NET Core 2.0中增加的一个页面控制器框架,用于构建动态的.数据驱动的网站: ...
- vue 的准备项目架构环境配置
一.环境搭建 中国镜像 composer config repo.packagist composer https://packagist.phpcomposer.com 命令 composer in ...
- MySQLdb 部署
1.windows 下载后,直接安装即可 http://www.jb51.net/softs/73369.html#download 双击安装 MySQL-python-1.2.3.win32-py2 ...
- RocketMQ-广播模式消费
Rocketmq 消费者默认是集群的方式消费的,消费者还可以用广播的模式进行消费.广播模式消费就是所有订阅同一个主题的消费者都会收到消息.代码实现上其实很简单,就是在消费端添加 consumer.se ...
- spring boot 文件上传 文件过大 FileUploadBase$SizeLimitExceed
application.properties中加入 multipart.maxFileSizemultipart.maxRequestSize Spring Boot 1.3.x或者之前 multip ...
- impala集成sentry
1.安装配置sentry 详细步骤见上一篇安装配置sentry. 2.配置impala 注:以下配置未集成kerberos安全认证 在/etc/imapla/conf目录下创建sentry-site. ...
- laravel5.5 when()的用法
当你在使用where语句有前提条件时,比如某值为1的时候才执行where子句,否则不执行,这个时候,laravel5.5新出了一个简便方法when($arg,fun1[,fun2]). 具体用法如下: ...
- 使用copy命令合并二进制文件
CMD下的copy命令可以将一份或多份文件复制到另一个位置. 也具备连接文件的功能. 使用如下命令格式可以将多个二进制文件合并为一个二进制文件: copy /b file1+file2+...+f ...