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
(可选)由应用程序用来指定原子工作单元的单线程的、短期的对象。抽象底层的JDBC、JTA或CORBA事务的请求。一个会话可以跨越若干个事务。
l ConnectionProvider
(可选)产生JDBC连接的工厂。抽象Datasource或DriverManager的请求。不向应用程序暴露接口。
l TransactionFactory
(可选)产生事务的工厂。不向应用程序暴露接口。
在“轻量级”的体系结构中,应用程序通过Transaction/TransactionFactory和(或)ConnectionProvider接口与JTA或JDBC直接会话。
1.2 持续对象标识
应用程序可能会在两个会话中并发地访问持续状态相同的对象。但是无论如何,持续类的实例决不能在两个会话实例中共享。有两种不同的标识对象的方法:
Persistent Identity: foo.getId().equals( bar.getId() )
JVM Identity: foo==bar
这时,从特定会话中返回的对象是相等的。但是,当应用程序在两个会话中并发地访问“同一”(persistent identity)业务对象时,两个实例就会出现不同(JVM identity)。
这种方法委托Hibernate和数据库来关注并发(只要保证每个会话都在单线程内,应用程序就不需要同步任何业务对象)或对象标识(在同一个会话中,应用程序可以安全地使用==来比较对象)问题。
1.3 JMX集成
JMX是J2EE用来管理Java组件的标准。可以通过JMX标准的MBean来管理Hibernate,但是,因为大多数的应用服务器还不支持JMX,所以Hibernate也提供了一些非标准的配置机制。
待续……