程序员

Hibernate的使用(二)

2017-07-22  本文已影响0人  hddwsz

第二部分 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<OID,Object>)构成的,当调用save,update方法的时候,会存入数据库当中,还会放到缓存中一份,当调用get 方法的时候,第一次查询,先从缓存中取,如果没有,从数据库中查询然后放入缓存中,第二次查询,直接返回缓存中的数据.一级缓存的内部结构分为缓存区和快照区,缓存区就是存放缓存数据的地方,在缓存区的时候,会顺带着给给这个数据来一个副本放入快照区(拍个照片),对于快照区,里面的数据,我们程序员修改不了.

        二级缓存:  sessionFactory级别的缓存,不是程序自带,是插件形式,被redis替代.


(四)Hibernate的事务控制

事务的隔离级别

read uncommmit    :什么也解决不了                1

read commit           :只能解决脏读                   2

repeatable read     :解决脏读和不可重复读     4

serialzable              :解决所有,但是不用        8

默认使用数据库的隔离级别 ,mysql :4

在hibernate当中设置事务的隔离级别

<property name="hibernate.connection.isolation">4</property>


(五)Hibernate的复杂查询

1.Query(使用的是HQL语句来查询)

HQL:Hibernate Query Language,比较面向对象的查询方式,和SQL的语法相似,但查询的对象不再是表和字段,而是实体类和类中的属性.

使用Session对象的createQuery(String hql)方法

以实体类Customer举例

查询全部:

图2

条件查询:

图3

分页查询:

图4

排序查询:

图5

统计查询:

图6

投影查询:

图7

2.Criteria(使用对象和方法来查询)

QBC:Query By Criteria,是一种更加面向对象的查询方式,把查询语句以及条件全部转成了对象的方法.

使用Session对象createCriteria(Class clazz)方法

以实体类Customer举例

查询全部:

图8

条件查询:

图9

分页查询:

图10

排序查询:

图11

统计查询:

图12

离线查询:

图13

---------未完待续---------

上一篇下一篇

猜你喜欢

热点阅读