美文网首页程序员
Hibernate的使用(二)

Hibernate的使用(二)

作者: hddwsz | 来源:发表于2017-07-22 16:30 被阅读0次

    第二部分 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

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

    相关文章

      网友评论

        本文标题:Hibernate的使用(二)

        本文链接:https://www.haomeiwen.com/subject/hrdukxtx.html