Hibernate参考手册(第一章)

    技术2022-05-11  131

    Hibernate参考手册

    第一章 体系结构

    1.1 概述

    Hibernate体系结构图:

    从上图可知Hibernate使用数据库和配置数据来为应用程序提供数据持续服务的(和持续对象)。

    由于Hibernate具有可配置性、且支持多种实现方式,所以我们将从两个极端来展示Hibernate在运行时的详细体系结构。“轻量级”的体系结构将由应用程序提供JDBC连接、管理自己的事务。这种实现方式使用了Hibernate API的最小集合:

           “重量级”的体系结构抽象了底层的JDBC / JTA接口,并由Hibernate来关注这些细节:

           下面是上图中一些对象的定义:

    net.sf.hibernate.SessionFactory

    net.sf.hibernate.Session

           net.sf.hibernate.Transaction

    net.sf.hibernate.TransactionFactory

    net.sf.hibernate.connection.ConnectionProvider

    persistent objects and collections

    transient objects and collections

     

    l        SessionFactory

    经过编译、线程安全的映射缓存,用来产生会话的工厂,ConnectionProvider对象的客户。

    l        Session

    用来描述在应用程序和持续对象之间所进行会话的单线程的、短期的对象。该对象包装了JDBC连接,事务工厂,为应用程序管理持续对象。

    l        Persistent Objects and Collections

    容纳持续状态和业务功能的单线程的、短期的对象。他们可能是普通的JavaBeans,唯一特殊的是他们与会话相关联。

    l        Transient Objects and Collections

    没有与会话相关联的持续类的实例。他们可能由应用实例化但没有持续,也可能由关闭的会话所实例化。

    l        Transaction

    (可选)由应用程序用来指定原子工作单元的单线程的、短期的对象。抽象底层的JDBCJTACORBA事务的请求。一个会话可以跨越若干个事务。

    l        ConnectionProvider

    (可选)产生JDBC连接的工厂。抽象DatasourceDriverManager的请求。不向应用程序暴露接口。

    l        TransactionFactory

    (可选)产生事务的工厂。不向应用程序暴露接口。

    在“轻量级”的体系结构中,应用程序通过Transaction/TransactionFactory和(或)ConnectionProvider接口与JTAJDBC直接会话。

    1.2 持续对象标识

           应用程序可能会在两个会话中并发地访问持续状态相同的对象。但是无论如何,持续类的实例决不能在两个会话实例中共享。有两种不同的标识对象的方法:

           Persistent Identity: foo.getId().equals( bar.getId() )

    JVM Identity:              foo==bar

    这时,从特定会话中返回的对象是相等的。但是,当应用程序在两个会话中并发地访问“同一”(persistent identity)业务对象时,两个实例就会出现不同(JVM identity)。

    这种方法委托Hibernate和数据库来关注并发(只要保证每个会话都在单线程内,应用程序就不需要同步任何业务对象)或对象标识(在同一个会话中,应用程序可以安全地使用==来比较对象)问题。

    1.3 JMX集成

           JMXJ2EE用来管理Java组件的标准。可以通过JMX标准的MBean来管理Hibernate,但是,因为大多数的应用服务器还不支持JMX,所以Hibernate也提供了一些非标准的配置机制。

     

     待续……


    最新回复(0)