一、数据库的隔离级别

  脏读 不可重复读 幻读
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. python练习 英文字符的鲁棒输入+数字的鲁棒输入

    鲁棒 = Robust 健壮 英文字符的鲁棒输入 描述 获得用户的任何可能输入,将其中的英文字符进行打印输出,程序不出现错误.‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪ ...

  2. QT_QGIS_基本使用

    QT_QGIS_基本使用 1.新建画布 2.添加矢量图层 ​ 1.打开矢量图层 ​ 2.新建矢量图层 ​ 1.添加几何要素--点 ​ 2.添加几何要素--线 3.添加栅格图层 ​ 1.打开栅格图层 小 ...

  3. 网络测速神器:SpeedTest深度指南

    最近在测试一个项目,里面涉及到一个测试case:在linux服务器上,当网络带宽较差时,观察服务的消息处理能力和表现.限制网卡带宽有许多方法,比如Wondershaper或者ethtool.那验证限速 ...

  4. 阿里Java中级开发测试相关试题及答案

    ------------恢复内容开始------------ 1.JSP文件上传的HTML标签代码定义是? A. <input type="text" name=" ...

  5. Unity Job System

    https://docs.unity3d.com/Manual/JobSystem.html https://github.com/Unity-Technologies/EntityComponent ...

  6. 下拉列表被flash覆盖的解决方法

    做鼎闻有一段时间了,有的banner轮播图的地方用flash替换的时候,就会导致上面的导航条下拉列表被flash覆盖,找了一段时间没有得到有效的解决方法,后来知道关键是flash的这一属性{ &quo ...

  7. node中间件

    npm i body-parser post 请求主题中间件 const bodyParser = require('body-parser')   const bodyParser = requir ...

  8. 安装JDK的攻略

    打开浏览器搜索JDK官网 单击Oracle下的JDK Download. 如果英语不好就直接打开浏览器自带翻译功能,根据自己的系统以及相应版本,下载对应的JDK 根据安装提示进行安装,路径自己选择. ...

  9. UNIX编程艺术

    本文主要是 <UNIX编程艺术>的摘录,摘录的主要是我觉得对从事软件开发有用的一些原则. 对于程序员和开发人员来说,如果完成某项任务所需要付出的努力对他们是个挑战却又恰好还在力所能及的范围 ...

  10. 【漫话DevOps】Agile,CI/CD,DevOps

    随着DevOps理念的普及与扩散,可能会被一大堆名字概念搞的莫名其妙,理清它们之间的关系可以帮助团队知道DevOps如何落地,改善工作流程. Here's a quick and easy way t ...