一、数据库的隔离级别

  脏读 不可重复读 幻读
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的更多相关文章

  1. Hibernate4.3基础知识1

    一.Hibernate 开发环境搭建 4.3 1.导包    2.创建hibernate.cfg.xml配置文件   3.创建实体类   4.创建映射文件 实体类名.hbm.xml  配置文件 二.h ...

  2. .NET面试题系列[1] - .NET框架基础知识(1)

    很明显,CLS是CTS的一个子集,而且是最小的子集. - 张子阳 .NET框架基础知识(1) 参考资料: http://www.tracefact.net/CLR-and-Framework/DotN ...

  3. RabbitMQ基础知识

    RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...

  4. Java基础知识(壹)

    写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...

  5. selenium自动化基础知识

    什么是自动化测试? 自动化测试分为:功能自动化和性能自动化 功能自动化即使用计算机通过编码的方式来替代手工测试,完成一些重复性比较高的测试,解放测试人员的测试压力.同时,如果系统有不份模块更改后,只要 ...

  6. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  7. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  8. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  9. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

随机推荐

  1. App 自动化,Appium 凭什么使用 UiAutomator2?

    1. UiAutomator2 是什么 可能很多人对 UiAutomator2 和 UiAutomator 傻傻分不清楚 UiAutomator 是 Google 开发的一款运行在 Android 设 ...

  2. 两台Windows Server 2012 R2数据库同步

    文件服务器/备库(192.168.0.1) 数据库服务器/备份文件服务器(192.168.0.2) 数据库实时同步 一.在主数据库服务器里,同样打开隐藏文件,找到C:\ProgramData\MySQ ...

  3. oracle备份之恢复管理目录

    一.管理恢复目录 #现实应用中一般都是专门新建一个rman 数据库,给所有的数据库做catalog1.建立恢复目录 #建立恢复目录表空间SQL> create tablespace rman_t ...

  4. spring集成shiro,事务失效问题 not eligible for auto-proxying

    BeanPostProcessor bean实例化顺序有关,@Configuration会最先实例化,也就是在spring启动完成之前. 导致Configuration中使用的注入,没能在spring ...

  5. Laptop(线段树+离散化)

    链接:https://ac.nowcoder.com/acm/contest/16/A来源:牛客网 题目描述 FST是一名可怜的小朋友,他很强,但是经常fst,所以rating一直低迷. 但是重点在于 ...

  6. 深入了解Netty【一】BIO、NIO、AIO简单介绍

    引言 在Java中提供了三种IO模型:BIO.NIO.AIO,模型的选择决定了程序通信的性能. 1.1.使用场景 BIO BIO适用于连接数比较小的应用,这种IO模型对服务器资源要求比较高. NIO ...

  7. 编写第一个 .NET 微服务

    介绍 本文的目的是:通过创建一个返回列表的简单服务,并在 Docker 容器中运行该服务,让您熟悉使用 .NET 创建微服务的构建过程. 安装 .NET SDK 要开始构建 .NET 应用程序,首先下 ...

  8. Linux—账号管理及命令使用详解

    关注微信公众号:CodingTechWork,一起学习进步. 引言   在Linux系统中,我们常常会看到目录或文件的所属关系: [root@linux01 ~]# ll -d test.sh -rw ...

  9. 原生javaScript导出表格数据

    <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...

  10. Python之 最全 Conda、pip 管理环境和安装包、更换源、解决HttpError等一些列问题

    在Anaconda中conda可以理解为一个工具,也是一个可执行命令,其核心功能是环境管理与包管理.所以对虚拟环境进行创建.删除等操作需要使用conda命令. conda install 和 pip ...