zoukankan      html  css  js  c++  java
  • Hibernate 中的核心接口与类

    Hibernate 中的核心接口与类

      Configuration

      SessionFactory接口  // 会话工厂

      Session接口        //会话    持久化管理器

      Transaction接口     //事务

    Query接口

    Criteria接口

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库


    Hibernate
    可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSPWeb应用中使用,最具革命意义的是,
    Hibernate
    可以在应用EJBJ2EE架构中取代CMP,完成数据持久化的重任。
    Hibernate
    的核心接口一共有5个,分别为:SessionSessionFactoryTransactionQueryConfiguration


    5个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。
    下面对这五的核心接口分别加以介绍。


    ·Session
    接口:Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句。
    但需要注意的是Session对象是非线程安全的。同时,Hibernatesession不同于JSP应用中的HttpSession
    这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSesion对象称为用户session


    ·SessionFactory
    接口:SessionFactroy接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。
    这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,
    当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory


    ·Configuration
    接口:Configuration接口负责配置并启动Hibernate,创建SessionFactory对象。在Hibernate的启动的过程中,
    Configuration
    类的实例首先定位映射文档位置、读取配置,然后创建SessionFactory对象。
    ·Transaction
    接口:Transaction接口负责事务相关的操作。它是可选的,开发人员也可以设计编写自己的底层事务处理代码。


    ·Query
    Criteria接口:QueryCriteria接口负责执行各种数据库查询。它可以使用HQL语言或SQL语句两种表达方式。
    Criteria
    接口与Query接口非常类似,它允许你创建并执行面向对象的标准化查询。值得注意的是Query接口也是轻量级的,它不能在Session之外使用。


    Callback
    接口 当一些有用的事件发生时――例如持久对象的载入、存储、删除时,Callback接口会通知Hibernate去接收一个通知消息。一般而言,Callback接口在用户程序中并不是必须的,但你要在你的项目中创建审计日志时,你可能会用到它。

    Session中读取记录

     Guestbookgb=(Guestbook)session.load(Guestbook.class,new Integer());

       Load(类名,主键)get方法类似

      更新 session.update(gb)

      删除session.delete(gb)

     

     

     get()VS load()

    getload方式是根据id取得一个记录
    下边详细说一下getload的不同,因为有些时候为了对比也会把find加进来。

    1.从返回结果上对比:
    load
    方式检索不到的话会抛出org.hibernate.ObjectNotFoundException异常
    get
    方法检索不到的话会返回null

    2.从检索执行机制上对比:
    get
    方法和find方法都是直接从数据库中检索
    load方法的执行则比较复杂
    ■ 
    首先查找sessionpersistentContext中是否有缓存,如果有则直接返回
    ■ 
    如果没有则判断是否是lazy,如果不是直接访问数据库检索,查到记录返回,查不到抛出异常
    ■ 
    如果是lazy则需要建立代理对象,对象的initialized属性为falsetarget属性为null
    ■ 
    在访问获得的代理对象的属性时,检索数据库,如果找到记录则把该记录的对象复制到代理对象的target上,并将initialized=true,如果找不到就抛出异常。

    3.根本区别说明
    ■ 
    如果你使用load方法,hibernate认为该id对应的对象(数据库记录)在数据库中是一定存在的,所以它可以放心的使用,它可以放心的使用代理来 延迟加载该对象。在用到对象中的其他属性数据时才查询数据库,但是万一数据库中不存在该记录,那没办法,只能抛异常。所说的load方法抛异常是指在使用 该对象的数据时,数据库中不存在该数据时抛异常,而不是在创建这个对象时(注意:这就是由于延迟加载在作怪)

    由于session中的缓存对于hibernate来说是个相当廉价的资源,所以在load时会先查一下session缓存看看该id对应的对象是否存在,不存在则创建代理。所以如果你知道该id在数据库中一定有对应记录存在就可以使用load方法来实现延迟加载。

    ■ 对于get方法,hibernate会确认一下该id对应的数据是否存在,首先在session缓存中查找,然后在二级缓存中查找,还没有就查数据库,数据库中没有就返回null

    对于loadget方法返回类型:虽然好多书中都这么说:“get()永远只返回实体类,但实际上这是不正确的,get方法如果在 session缓存中找到了该id对应的对象,如果刚好该对象前面是被代理过的,如被load方法使用过,或者被其他关联对象延迟加载过,那么返回的还是原先的代理对象,而不是实体类对象,如果该代理对象还没有加载实体数据(就是id以外的其他属性数据),那么它会查询二级缓存或者数据库来加载数据,但是返回的还是代理对象,只不过已经加载了实体数据。

    get方法首先查询session缓存,没有的话查询二级缓存,最后查询数据库;反而load方法创建时首先查询session缓存,没有就创建代理,实际使用数据时才查询二级缓存和数据库。

    4.简单总结

    总之对于getload的根本区别,一句话,hibernate对于load方法认为该数据在数据库中一定存在,可以放心的使用代理来延迟加载,如果在使用过程中发现了问题,只能抛异常;而对于get方法,hibernate一定要获取到真实的数据,否则返回null

  • 相关阅读:
    第五次站立会议
    第四次站立会议
    迪杰斯特拉算法求最短路径问题
    数组课堂作业
    java2
    Java书写add函数
    《大道至简》第二章(是懒人创造了方法)读后感
    大二暑假周进度报告之四
    大二暑假周进度报告之三
    大二暑假周进度报告之二
  • 原文地址:https://www.cnblogs.com/a1280055207/p/2851198.html
Copyright © 2011-2022 走看看