第一天

Hibernate是一个持久层ORM框架。两个配置文件,

类名.hbm.xml类的属性和表的列对应

hibernate.cfg.xml核心配置文件

Hibernate相关API:

Configuration配置对象,读取hibernate的xml核心配置,也可以加载映射文件

Sessionfactory工厂对象,在hibernate中起到缓冲区作用,负责hibernate的初始化和建立session对象,它可以将自动生成sql语句,映射数据和可重复利用的数据放入这个缓冲区中,同时它还保存了数据库的所有映射关系,维护了二级缓存

特点:

1线程安全的,可以同一个实例多个线程

2重量级的,不能随便创建和销毁

Session:应用程序和数据库之间交互操作的单线程对象,是hibernate的运作中心,是为持久化数据提供创建读取删除的能力,所有持久化操作必须在session的管理下才可以进行操作

Session实例的两种获得方法

1openSession

2getCurrentSession(优先)

区别:open的要手动关闭,get的那个创建的实例会绑定到当前线程,提交或者回滚的时候会自动关闭

事务,session.beginTransaction开启

commit方法,提交相关的实例

rollback方法,撤销事务操作

第二天

主键类型,自然主键(有业务含义)和代理主键(无业务含义)

session的api,查询get和load的区别

get是立即加载,load是延迟加载

方言:根据配置的方言生成相应的sql语句

主键生成策略uuid和native等

持久化对象的三种状态:

瞬时态,不存在持久化标识OID(相当于主键值),尚未与Hibernate Session关联

持久态,存在持久化OID,加入到了Session缓存中,并且相关联的Session没有关闭,数据库中有对应的记录

脱管态,存在持久化标识OID,并且仍然与数据库中的数据存在关联,只是失去了与当前Session的关联

持久态对象能自动更新数据库

Hibernate的一级缓存,提供运行性能,指的是session缓存,减少对数据库的访问次数

一级缓存的内部结构,快照区,确保一级缓存中的数据和数据库中的数据一致,不一致会执行update语句

第三天

级联操作,双向关联会产生多余的sql语句,

处理方法就是这两个,cascade和inverse,他们区别如下

cascade操作一个对象的时候,是否操作其关联对象

inverse强调的是外键维护权

左外连接:返回包括左表的所有记录和右表中符合连接条件的记录

第四天

使用session的5种查询:

HQL:代表Hibernate的查询操作,针对query来操作,语法像sql语法,但是是完全面向对象的

QBC:完全面向对象,可拓展条件的api,不需要考虑底层实现和sql语句,针对Criteria来操作

SQLQuery:接受sql的查询

对象图导航检索,根据已加载的对象,导航到他的关联对象,前提是映射文件上配置多对一的关系

OID,用get和load方法加载某条记录对应的对象

投影查询:返回指定的列的数据

离线条件查询:脱离session,将dao层的的语句转移到别的层

抓取策略:是提升性能的一种手段,联合延迟加载使用,

抓取策略:查询到某个对象的时候,如何抓取其关联对象,这个可以配置完成,在关联对象的标签上配置fetch属性

类级别的延迟加载我们一般不进行修改

关联级别的延迟加载,通常在<set>和<many-to-one>上进行配置

<set>默认true,采用延迟加载

<many-to-one>默认proxy,的延迟加载取决于一的一方上的lazy属性的值

<set> 默认select,发送普通的select语句

<many-to-one>,默认select,发送普通的select语句查询相关对象

总结fetch和lazy的作用,fetch主要控制抓取对象的时候发送SQL语句的格式的,lazy主要控制查询其关联对象的时候是否采用延迟加载

batch-size批量抓取

Hibernate复习的更多相关文章

  1. Hibernate复习之Hibernate基本介绍

    众所周知.眼下流行的面向对象的对象关系映射的Java持久层框架有MyBatis和Hibernate.他们都是对象关系映射ORM. 解决的主要问题就是对象-关系的映射.域模型和关系模型都分别建立在概念模 ...

  2. hibernate复习第(4)天

    1.hibernate的映射类型.hbm.xml中property中的type属性.这个type属性是表示持久化类中的属性对应数据库中的什么数据类型,用来构建一种映射type的可选值:hibernat ...

  3. hibernate复习第(三)天

    今日要点: 1.继承关系映射 一个表对应一个映射树(subclass) 一个子类一个表,子类只有父类没有的字段(joined-subclass) 鉴别器和内连接结合使用(subclass join) ...

  4. hibernate复习第(二)天

    今日要点: 关联映射 多对一(Employee - Department) 一对多(Department - Employee) 一对一(Person - IdCard) 多对多(teachet - ...

  5. hibernate复习第(一)天

    首先导入jar. 这个版本是3.2.5 开发流程: 1.由Domain object ->mapping ->db (官方推荐) 2.由DB开始,使用工具生成mapping和Domain ...

  6. HIBERNATE知识复习记录4-HQL和QBC

    Hibernate中共提供了三种检索方式:HQL(Hibernate Query Language).QBC.QBE(Query By Example). HQL 是Hibernate Query L ...

  7. HIBERNATE知识复习记录3-关联关系

    先上一张图,关于几种关系映射: 抄一段解释: 基本映射是对一个实体进行映射,关联映射就是处理多个实体之间的关系,将关联关系映射到数据库中,所谓的关联关系在对象模型中有一个或多个引用.关联关系分为上述七 ...

  8. HIBERNATE知识复习记录1-连接及常用方法

    要去面试了,复习一下HIBERNATE的相关知识吧,原来边看视频边写的代码如下,已经分不清先后次序了,大致看一看吧. 先看下总的配置文件hibernate.cfg.xml: <?xml vers ...

  9. Hibernate 知识点复习

    核心接口 1  Configuration接口负责配置并启动Hibernate,创建SessionFactory对象 2  SessionFactory接口负责初始化Hibernate.它充当数据存储 ...

随机推荐

  1. MyEclipse项目的BUG修复错误类型

    一.The type java.lang.CharSequence cannot be resolved. It is indirectly referenced from required .cla ...

  2. 2015-10-20 sql2

                                                                      SQL SERVER(二) 三.插入,更新,删除,添加 3.1ins ...

  3. learning makefile = and :=

  4. LeetCode 695 岛屿的最大面积

    题目: 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被水包围着. 找到给定的二 ...

  5. 一月分四周的JAVA实现方法

    需求:给定任意一个月,如何按照中国周的习惯,把一个月分成四个时间段 (1)以自然周为划分依据 (2)不能跨月 (3)把首尾自然周,天数较少的合并到其最近的自然周里面 (4)最后结果应该是吧一个月分成四 ...

  6. javascript 统计字符串中每个字符出现的次数

    var str = "abdcadfasfdbadfafdasdfasyweroweurowqrewqrwqrebwqrewqrejwq;;"; // console.log(nu ...

  7. 使用jsoup轻松爬数据

    刚刚学习爬虫,感觉使用jsoup爬虫挺容易的.记录一下自己爬取数据的过程. Jsoup介绍: Jsoup 是一个 Java 的开源HTML解析器,可直接解析某个URL地址.HTML文本内容.使用Jso ...

  8. Mysql 复制一个新表

    1.复制表结构及数据到新表CREATE TABLE 新表 SELECT * FROM 旧表这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable;来 ...

  9. C# 开发Modbus Rtu客户端 modbus测试Demo,Modbus 串口通信 , 虚拟MODBUS-RTU测试

    前言 本文将使用一个NuGet公开的组件技术来实现一个ModBus RTU的客户端,方便的对Modbus rtu的服务器进行读写,这个服务器可以是电脑端C#设计的,也可以是PLC实现的,也可以是其他任 ...

  10. SQL注入之Sqli-labs系列第三十六关(基于宽字符逃逸GET注入)和三十七关(基于宽字节逃逸的POST注入)

    0X1 查看源码 function check_quotes($string) { $string= mysql_real_escape_string($string); return $string ...