对NHibernate体系结构的非常高层的概览:
这幅图展示了NHibernate使用数据库和配置文件数据来为应用程序提供持久化服务(和持久化的对象)。
我们试图显示更多NHibernate运行时体系结构的细节。 但挺不幸的,NHibernate是比较灵活的并且提供了好几种不同的运行方式。我们展示一下两种极端情况。轻型体系中,应用程序自己提供ADO.NET连接,并且自行管理事务。这种方式使用了NHibernate API的一个最小子集。
全面解决体系中,对于应用程序来说,所有的底层ADO.NET API都被抽象了,NHibernate会替你照管所有的细节。
下面是图中一些对象的定义:
-
SessionFactory (
-
对属于单一数据库的编译过的映射文件的一个线程安全的,不可变的缓存快照。它是
Session
的工厂,是ConnectionProvider
的客户。可以持有一个可选的(第二级)数据缓存,可以在进程级别或集群级别保存可以在事物中重用的数据。
会话,Session ( -
单线程,生命期短促的对象,代表应用程序和持久化层之间的一次对话。封装了一个ADO.NET连接。也是
Transaction
的工厂。保存有必需的(第一级)持久化对象的缓存,用于遍历对象图,或者通过标识符查找对象。
持久化对象(Persistent)及其集合(Collections)
-
生命期短促的单线程的对象,包含了持久化状态和商业功能。它们可能是普通的对象,唯一特别的是他们现在从属于且仅从属于一个
Session
。一旦Session
被关闭,他们都将从Session
中取消联系,可以在任何程序层自由使用(比如,直接作为传送到表现层的DTO,数据传输对象)。
临时对象(Transient Object)及其集合(Collection)
-
目前没有从属于一个
Session
的持久化类的实例。他们可能是刚刚被程序实例化,还没有来得及被持久化,或者是被一个已经关闭的Session
所实例化的。
事务Transaction ( -
(可选) 单线程,生命期短促的对象,应用程序用它来表示一批工作的原子操作。是底层的ADO.NET事务的抽象。一个Session某些情况下可能跨越多个
Transaction
事务。
ConnectionProvider ( -
(可选)ADO.NET连接的工厂。从底层的
IDbConnection
抽象而来。对应用程序不可见,但可以被开发者扩展/实现。
TransactionFactory ( -
(可选)事务实例的工厂。对应用程序不可见,但可以被开发者扩展/实现。
NHibernate.ISessionFactory
)
NHibernate.ISession
)
NHibernate.ITransaction
)
NHibernate.Connection.ConnectionProvider
)
net.sf.hibernate.TransactionFactory
)
在上面的轻型结构中,程序没有使用Transaction
/ TransactionFactory
或者ConnectionProvider
API,直接和ADO.NET对话了。