更多内容请访问http://softtrade.vicp.net 
对Hibernate非常高层的概览:  
这幅图展示了Hibernate使用数据库和配置文件数据来为应用程序提供持久化服务(和持久化的对象)。  
让我们更细致地观察一下运行时的体系结构。 挺不幸的,Hibernate是比较复杂的,提供了好几种不同的运行方式。我们展示一下两种极端情况。轻型体系中,应用程序自己提供JDBC连接,并且自行管理事务。这种方式使用了Hibernate API的一个最小子集。  
全面解决体系中,对于应用程序来说,所有的底层JDBC/JTA API都被抽象了,Hibernate会替你照管所有的细节。  
下面是图中一些对象的定义:  
- SessionFactory (net.sf.hibernate.SessionFactory) 
 - 
对编译过的映射文件的一个线程安全的,不可变的缓存快照。它是Session的工厂。是ConnectionProvider的客户。  
可能持有事务之间重用的数据的缓存。  
 - 会话,Session (net.sf.hibernate.Session) 
 - 
单线程,生命期短促的对象,代表应用程序和持久化层之间的一次对话。封装了一个JDBC连接。也是Transaction的工厂。  
持有持久化对象的缓存。  
 - 持久化对象(Persistent Object)及其集合(Collection) 
 - 
生命期短促的单线程的对象,包含了持久化状态和商业功能。它们可能是普通的JavaBeans,唯一特别的是他们现在从属于且仅从属于一个Session。  
 - 临时对象(Transient Object)及其集合(Collection) 
 - 
目前没有从属于一个Session的持久化类的实例。他们可能是刚刚被程序实例化,还没有来得及被持久化,或者是被一个已经关闭的Session所实例化的。  
 - 事务,Transaction (net.sf.hibernate.Transaction) 
 - 
(可选) 单线程,生命期短促的对象,应用程序用它来表示一批工作的原子操作。是底层的JDBC,JTA或者CORBA事务的抽象。一个Session可能跨越多个Transaction 事务。  
 - ConnectionProvider (net.sf.hibernate.connection.ConnectionProvider) 
 - 
(可选)JDBC连接的工厂和池。从底层的Datasource或者 DriverManager抽象而来。对应用程序不可见。  
 - TransactionFactory (net.sf.hibernate.TransactionFactory) 
 - 
(可选)事务实例的工厂。对应用程序不可见。     
在上面的轻型结构中,程序没有使用Transaction / TransactionFactory 或者ConnectionProvider API,直接和JTA/JDBC对话了。   
2.2. 持久化对象标识(Persistent Object Identity )  
 
应用程序可能同时在两个不同的session中存取同一个持久化对象。然而,两个Session实例是不可能共享一个持久化类的实例的。有两种不同的用来辨别对象是否相同的方法。  
- Persistent Identity,持久化辨别 
 - 
foo.getId().equals( bar.getId() )  
 - JVM Identity, JVM辨别 
 - 
foo==bar     
对于同一个特定的Session返回的对象来说,这二者是等价的。然而,当程序并行在两个不同的session中访问含义上“相同”(持久化辨别)的商业对象时,两个对象实例从JVM的角度上来看却是“不同”的(JVM辨别)  
这种方式把并行访问(应用程序不需要对任何商业对象进行同步,只要求遵循每个Session一个线程的原则)和对象辨别(在应用程序的一个session之中,可以安全的用==来比较对象)的难题留给了Hibernate和数据库。   
JMX是用来管理Java组件的J2EE标准。Hibernate可以被标准的JMX Mbean管理,但是因为大多数程序还没有支持JMX,Hibernate也支持一些非标准的配置方式。  
请查阅Hibernate网站,可以得到关于如何在JBOSS中把Hibernate配置成为一个JMX组件的更多信息。   
 
 
  |