Hibernate4.3基础知识2
一、数据库的隔离级别
| 脏读 | 不可重复读 | 幻读 | |
| Read uncommited | Y | Y | Y |
| Read commited | N | Y | Y |
| Repeatable read | N | N | Y |
| Serializable | N | N | N |
查询MySql隔离级别:select @@gloable.tx_isolation,@@tx_isolation
二、Session的flush
1、使用UUID主键生成策略测试flush
1 User user = new User();
2 user.setUname("张三");
3 user.setGender(1);
4 user.setBirthday(new Date());
5 //因为是uuid方式生成的主键,由Session给生成,把user对象存储在Session的临时存储区
6 session.save(user);
7 //发出sql语句,清理临时存储区,把dirty变成false
8 session.flush();
9 tx.commit();
2、使用native主键生成策略测试flush
1 //因为是使用native方式生成主键,所以save的时候要发出sql来产生主键,持久区有数据,dirty是true
2 session.save(user);
3 //把dirty变成false
4 session.flush();
//因为是使用native方式生成主键,所以save的时候要发出sql来产生主键,持久区有数据,dirty是true
session.save(user);
//把user逐出Session
session.evict(user);
//Session中没有数据flush没有意义
session.flush();
//但是commit依然会把数据提交到数据库,因为sql已经发出了
tx.commit();
3、session的flush能完成大量数据入库的功能
1 for(int i = 0; i < 100009; i++){
2 User user = new User();
3 user.setUname("张三");
4 user.setGender(1);
5 user.setBirthday(new Date());
6 session.save(user);
7 if(i%100 == 0){
8 session.flush();
9 }
10 }
11 session.flush();
12 tx.commit();
三、多对一:
1、创建模型: 多的一端引入一的一端作为类的成员变量,
2、配置映射文件:
1 <!-- 多对一关系映射 cascade: delete save-update all -->
2 <many-to-one name="team" column="t_No" cascade="save-update"></many-to-one>
cascade级联,在保存多的一端的时候,会自动级联保存一的一端
四、一对一单向关联:
1、创建模型:
1 public class IDCard {
//主键
2 private Integer cardId;
3 private String cardNo;
//指定一对一的关系
4 private Emp emp;
5 }
2、配置映射文件
1 <class name="IDCard" table="t_id_card">
2 <id name="cardId" column="emp_No">
3 <!-- 使用外键方式生成主键 -->
4 <generator class="foreign">
5 <param name="property">emp</param>
6 </generator>
7 </id>
8 <property name="cardNo" column="card_no"></property>
9 <!-- 指定一对一关系 constrained:建表时带有外键约束 -->
10 <one-to-one name="emp" constrained="true"></one-to-one>
11 </class>
五、一对一双向关联:
1、创建模型: 在双放都引入对应的一对一关系
2、配置映射文件
1 <one-to-one name="card"></one-to-one>
六、一对多单向:
1、创建模型:在一的一方,通过集合引入多的一方
2、配置映射文件:
一对多是有缺陷的,保存的时候如果多的一端的外键是非空,一对多的保存就不成立
<set name="set">
<!-- key:在多的一端的表中要产生的外键 column:外键名称 -->
<key column="t_id"></key>
<!-- one-to-many:指定多的一端的类 class:多的一端的类 -->
<one-to-many class="Emp"/>
</set>
七、一对多双向:
1、创建模型:在多的一方,再添加一的一端的引入
2、配置映射文件:
1 <!--
2 指定多对一的关系:
3 name:一的一端属性名
4 column:多的一端的表中要产生的外键字段,注意在team.hbm.xml中已经配置了这个外键,
5 现在要求我们配置的这个外键要和team.hbm.xml中配置的多的一端外键名称相同,
6 因为这两个配置指的是同一个列
7 -->
8 <many-to-one name="team" column="t_id"></many-to-one>
八、多对多单向:
1、创建模型:在多的一方,以集合形式引入另一个多的一方
2、配置映射文件:
1 <!-- 配置set,设置多对多的单端集合 table:要产生的中间表 -->
2 <set name="roles" table="emp_role" cascade="save-update">
3 <!-- 把当前表的主键给中间表作为外键 column:当前主键名称 -->
4 <key column="emp_No"></key>
5 <many-to-many class="Role" column="role_id"></many-to-many>
6 </set>
九、多对多双向:
1、创建模型:双发都引入对方
2、配置映射文件“
十、延迟加载:
1、class上的延迟加载: get默认不使用延迟加载,load使用延迟加载,延迟加载必须在同一个session范围内
2、集合的延迟加载:默认是有延迟加载的, 集合的加载效果不受类上延迟加载影响
如果查询集合数量时候,需要用lazy="extra" 提高效率
3、单端延迟加载
针对多对一 和 一对一 的延迟加载,默认是lazy=proxy来使用延迟加载
Hibernate4.3基础知识2的更多相关文章
- Hibernate4.3基础知识1
一.Hibernate 开发环境搭建 4.3 1.导包 2.创建hibernate.cfg.xml配置文件 3.创建实体类 4.创建映射文件 实体类名.hbm.xml 配置文件 二.h ...
- .NET面试题系列[1] - .NET框架基础知识(1)
很明显,CLS是CTS的一个子集,而且是最小的子集. - 张子阳 .NET框架基础知识(1) 参考资料: http://www.tracefact.net/CLR-and-Framework/DotN ...
- RabbitMQ基础知识
RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...
- Java基础知识(壹)
写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...
- selenium自动化基础知识
什么是自动化测试? 自动化测试分为:功能自动化和性能自动化 功能自动化即使用计算机通过编码的方式来替代手工测试,完成一些重复性比较高的测试,解放测试人员的测试压力.同时,如果系统有不份模块更改后,只要 ...
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
随机推荐
- App 自动化,Appium 凭什么使用 UiAutomator2?
1. UiAutomator2 是什么 可能很多人对 UiAutomator2 和 UiAutomator 傻傻分不清楚 UiAutomator 是 Google 开发的一款运行在 Android 设 ...
- 两台Windows Server 2012 R2数据库同步
文件服务器/备库(192.168.0.1) 数据库服务器/备份文件服务器(192.168.0.2) 数据库实时同步 一.在主数据库服务器里,同样打开隐藏文件,找到C:\ProgramData\MySQ ...
- oracle备份之恢复管理目录
一.管理恢复目录 #现实应用中一般都是专门新建一个rman 数据库,给所有的数据库做catalog1.建立恢复目录 #建立恢复目录表空间SQL> create tablespace rman_t ...
- spring集成shiro,事务失效问题 not eligible for auto-proxying
BeanPostProcessor bean实例化顺序有关,@Configuration会最先实例化,也就是在spring启动完成之前. 导致Configuration中使用的注入,没能在spring ...
- Laptop(线段树+离散化)
链接:https://ac.nowcoder.com/acm/contest/16/A来源:牛客网 题目描述 FST是一名可怜的小朋友,他很强,但是经常fst,所以rating一直低迷. 但是重点在于 ...
- 深入了解Netty【一】BIO、NIO、AIO简单介绍
引言 在Java中提供了三种IO模型:BIO.NIO.AIO,模型的选择决定了程序通信的性能. 1.1.使用场景 BIO BIO适用于连接数比较小的应用,这种IO模型对服务器资源要求比较高. NIO ...
- 编写第一个 .NET 微服务
介绍 本文的目的是:通过创建一个返回列表的简单服务,并在 Docker 容器中运行该服务,让您熟悉使用 .NET 创建微服务的构建过程. 安装 .NET SDK 要开始构建 .NET 应用程序,首先下 ...
- Linux—账号管理及命令使用详解
关注微信公众号:CodingTechWork,一起学习进步. 引言 在Linux系统中,我们常常会看到目录或文件的所属关系: [root@linux01 ~]# ll -d test.sh -rw ...
- 原生javaScript导出表格数据
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
- Python之 最全 Conda、pip 管理环境和安装包、更换源、解决HttpError等一些列问题
在Anaconda中conda可以理解为一个工具,也是一个可执行命令,其核心功能是环境管理与包管理.所以对虚拟环境进行创建.删除等操作需要使用conda命令. conda install 和 pip ...