第二部分 Hibernate的底层实现
(一)主键生成策略
主键分为自然主键(用一个和自身相关的属性作为数据库中的主键)和代理主键(用一个和自身没有关系的属性作为主键),Hibernate的主键生成策略针对的就是代理主键.
主键生成策略如下:
数据库如果是MySQL使用identity,如果是Oracle使用sequence,当然你如果嫌记得麻烦可以采用native,Hibernate会根据你的数据库类型自动选择identity还是sequence.
(二)持久化类
持久化类 = 实体类 + 映射文件
实体类的编写规则:(1)需要一个公开的类,公开的无参构造
(2)私有的属性,并提供公开的get,set方法
(3)需要一个持久化标识OID
(4)实现Serializable接口
(5)实体类不能使用final修饰
(6)使用包装类型替换基本类型(可以避免一些歧异)
(三)Hibernate的缓存机制
Hibernate将持久化类分为三种状态:瞬时态,持久态,托管态(游离态),区分这三种状态的标志就是有没有和session建立关系和有没有id.
Hibernate执行save方法之前,也就是对象被保存到数据库前,它没有id也没有和session建立关系,所以他是瞬时态;执行方法后有id也和session建立联系,所以他是持久态;执行close方法后,session被关闭,他成为托管态.
持久态对象会自动更新数据库,是建立在Hibernate的一级缓存基础上.
Hibernate的缓存是用来提高数据库的访问效率,分为一级缓存和二级缓存.
一级缓存: session级别的缓存,随着session的创建而创建,随着session的销毁而销毁,程序自带,不可卸载.一级缓存有一系列的集合(Map
二级缓存: sessionFactory级别的缓存,不是程序自带,是插件形式,被redis替代.
(四)Hibernate的事务控制
事务的隔离级别
read uncommmit :什么也解决不了 1
read commit :只能解决脏读 2
repeatable read :解决脏读和不可重复读 4
serialzable :解决所有,但是不用 8
默认使用数据库的隔离级别 ,mysql :4
在hibernate当中设置事务的隔离级别
(五)Hibernate的复杂查询
1.Query(使用的是HQL语句来查询)
HQL:Hibernate Query Language,比较面向对象的查询方式,和SQL的语法相似,但查询的对象不再是表和字段,而是实体类和类中的属性.
使用Session对象的createQuery(String hql)方法
以实体类Customer举例
查询全部:
条件查询:
分页查询:
排序查询:
统计查询:
投影查询:
2.Criteria(使用对象和方法来查询)
QBC:Query By Criteria,是一种更加面向对象的查询方式,把查询语句以及条件全部转成了对象的方法.
使用Session对象createCriteria(Class clazz)方法
以实体类Customer举例
查询全部:
条件查询:
分页查询:
排序查询:
统计查询:
离线查询:
---------未完待续---------