Hibernate参考文档——第2章体系结构

href="http://www.hibernate.org/hib_docs/v3/reference/en/shared/css/html.css" type="text/css" rel="stylesheet" /> title="HIBERNATE - Relational Persistence for Idiomatic Java" href="index.html" rel="home" /> title="HIBERNATE - Relational Persistence for Idiomatic Java" href="index.html" rel="up" /> title="Chapter 1. Introduction to Hibernate" href="tutorial.html" rel="previous" /> title="Chapter 3. Configuration" href="session-configuration.html" rel="next" />

第二章. 体系结构

2.1. 概览

一个非常高层次的Hibernate体系结构图:

这幅图展示了Hibernate使用数据库和配置文件数据来为应用程序提供持久化服务(和持久化的对象)。

我们展示一个更详细的运行时结构图。不幸的是,Hibernate很灵活并且支持并且支持多种运行方式。我们展示一下两种极端情况。轻型体系中,应用程序自己提供JDBC连接,并且自行管理事务。这种方式使用了Hibernate API的一个最小子集。

全面解决体系中,对于应用程序来说,所有的底层JDBC/JTA API都被抽象了,Hibernate会替你照管所有的细节。

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

SessionFactory (org.hibernate.SessionFactory)

是对单一数据库的已编译映射文件的线程安全的不可变的高速缓存。它是Session的工厂,是ConnectionProvider的客户。可能持有一个可选的可在进程级别或集群级别事务间重用的(二级)数据缓存。

会话 Session (org.hibernate.Session)

单线程的短生命周期的对象,是应用程序和持久化存储的一次对话。封装了一个JDBC连接,也是Transaction的工厂。保持一个持久化对象的强制(第一级)缓存,用来遍历对象图或者根据标识符查询对象。

持久化对象和集合 ( Persistent objects and collections)

包含持久化状态和商业功能的短生命周期的单线程对象。它们可能是普通的JavaBean或POJO,唯一特别的是它们通常跟且只跟一个Session相关联。一旦Session被关闭,它们将游离并能在任何应用层被使用(例如,直接作为表示层的数据传输对象)。

临时分离对象和集合(Transient and detached objects and collections)

当前没有跟Session关联的持久化类的实例。它们可能是应用程序实例化但是还没有持久化的或者是被已关闭的Session实例化的。

事务 Transaction (org.hibernate.Transaction)

(可选)单线程,短生命周期的对象,应用程序用它来表示一批工作的原子操作。是底层JDBC,JTA或者CORBA事务的抽象。一个Session某些情况下可能跨越多个Transaction 事务。然而,使用底层API或者Transaction进行的事务划分不是可选的。

ConnectionProvider (org.hibernate.connection.ConnectionProvider)

(可选) JDBC连接的工厂和连接池。底层 DatasourceDriverManager的抽象应用。对应用程序不可见,但可以被开发者扩展/实现。

TransactionFactory (org.hibernate.TransactionFactory)

(可选)事务实例的工厂。对应用程序不可见,但可以被开发者扩展/实现。

扩展接口(Extension Interfaces)

Hibernate 提供很多可选的可扩展接口,你可以实现它们来定制你的客持久化层的行为。在API中查看更多细节。

 

在上面的轻型结构中,程序没有使用Transaction / TransactionFactory 或者ConnectionProvider API,直接和JTA/JDBC对话了。

2.2. 实例状态

一个持久化类的实例可以使根据持久化上下文(persistence context)定义的三种不同状态之一。Hibernate的Session对象就是持久化上下文(persistence context):

临时状态(transient)

这样的实例没有从来没有跟任何的持久化上下文相关联。它没有持久化的标识(主键值)。

持久化状态(persistent)

实例现在正跟一个持久化上下文相关联。它有持久化的标识(主键值),可能对应跟数据库中的某一行。在一个特定的持久化上下文中,Hibernate 保证 持久化标识和Java标识是等价的(在对象的内存中)。

游离状态(detached)

曾经跟持久化上下文关联但是上下文已经关闭或者在另一个进程中连续使用的实例。它有持久化标识并且可能对应数据库中的某一行。对于游离态的实例,Hibernate并不保证持久化标识和Java标识的关系。

2.3. JMX 集成

JMX是管理Java组件的J2EE标准。Hibernate可以被标准的JMX服务管理。我们在发行包中提供一个MBean的实现:org.hibernate.jmx.HibernateService

JBoss用户指南提供了怎样在JBoss应用服务器中将Hibernate作为JMX服务发布的例子。在JBoss应用服务器中,如果使用JMX还可以得到这些好处:

  • 会话管理(Session Management): Hibernate会话的生命周期能够自动被绑定到JTA事务中。这意味着不再需要手动地打开和关闭会话,这将成为JBoss EJB 拦截器的工作。你再也不必担心代码中事务的划分(除非你愿意用可选的Hibernate事务API写一个便捷的持久化层)。调用HibernateContext访问一个会话。

  • HAR deployment: 通常你使用JBoss服务部署描述符(在EAR或SAR文件中)部署Hibernate JMX服务,它支持Hibernate SessionFactory的所有常用配置操作。然而,你还是要在部署描述符中命名你所有的映射文件。

参考JBoss 应用服务器用户指南获得更多信息。

另一个JMX服务的有用的特征是Hibernate统计,参看 3.4.6节, “Hibernate 统计”

2.4. JCA 支持

Hibernate也可以配置成JCA连接器。更多细节请参考网站。请注意,Hibernate的JCA支持还是试验阶段。

2.5. 上下文的Session

很多使用Hiberante的应用程序需要一些“上下文”形式的会话,这样的会话的作用贯穿在整个上下文范围中。然而,在整个应用中定义上下文的条件通常是不同的;并且不同的上下文对当前概念也有不同的定义范围。使用Hibernate3.0以前的版本的应用程序要么利用自产的基于当前线程的上下文会话(像HibernateUtil一样的辅助类),要么利用提供代理/基于侦听的上下文会话的第三方框架(例如Spring或Pico)。

从 3.0.1开始,Hibernate增加了 SessionFactory.getCurrentSession()方法。 最初这种设想是JTA事务的用法,JTA事务定义了范围和当前会话的上下文。Hibernate团队获得了大量成熟的单机JTA事务管理器的实现,他们主张大部分应用程序应该使用JTA事务管理器不管是不是在J2EE容器中部署。基于此,基于JTA的上下文会话是你曾经需要用到的。

然而在 3.1中,SessionFactory.getCurrentSession()的后台处理现在可以插拔。为此,增加了一个新的扩展接口(org.hibernate.context.CurrentSessionContext) 和新的配置参数 (hibernate.current_session_context_class)来允许定义当前会话的范围和上下文的热插拔。

在Java文档中查看 org.hibernate.context.CurrentSessionContext 接口更详细的讨论。它定义了一个唯一的方法currentSession(),通过它接口的实现对跟踪当前上下文会话变得可靠。在下表里,Hibernate提供了接口的三个实现。

  • org.hibernate.context.JTASessionContext - 当前会话被JTA事务跟踪并检查。处理方法跟旧的JTA完全相同,也是唯一做法。在Java文档中查看详细信息。

  • org.hibernate.context.ThreadLocalSessionContext - 当前会话被执行的线程跟踪,在Java文档中查看详细信息。

  • org.hibernate.context.ManagedSessionContext - 当前会话被执行的线程跟踪,但是你应该在这个类中使用静态方法绑定和解除一个会话实例,它不会打开,刷新或关闭一个会话。

前两个实现提供了一种“一个会话一个数据库事务”的编程模式,也被称为是会话每请求(session-per-request)。一个Hibernate会话的开始和结束在数据库事务期间被定义。如果你在没有JTA的简单的JSE中使用可编程的数据库划分,建议你使用Hibernate事务API在你的代码中隐藏底层事务系统。如果你使用JTA,使用JTA接口划分事务。如果你在一个支持CMT的EJB容器中执行,事务界限会被明确定义,你不需要在代码中作任何事物或会话的划分。参考 第11章,事物和并发 获得更多信息和代码示例。

hibernate.current_session_context_class 配置参数定义了应该使用哪一个org.hibernate.context.CurrentSessionContext的实现 。注意,为了向后兼容,如果没有设置配置参数,而是配置了org.hibernate.transaction.TransactionManagerLookup ,Hibernate会使用org.hibernate.context.JTASessionContext。通常,这个参数只是命名要使用的实现类;上面的三个实现分别有简称“jta”,“thread”,和“managed”。

1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第二部分 - 关联映射 1.3.1. 映射Person类 1.3.2. 单向Set-based的关联 1.3.3. 使关联工作 1.3.4. 值类型的集合 1.3.5. 双向关联 1.3.6. 使双向连起来 1.4. 第三部分 - EventManager web应用程序 1.4.1. 编写基本的servlet 1.4.2. 处理与渲染 1.4.3. 部署与测试 1.5. 总结 2. 体系结构(Architecture) 2.1. 概况(Overview) 2.2. 实例状态 2.3. JMX整合 2.4. 对JCA的支持 2.5. 上下文相关的(Contextual)Session 3. 配置 3.1. 可编程的配置方式 3.2. 获得SessionFactory 3.3. JDBC连接 3.4. 可选的配置属性 3.4.1. SQL方言 3.4.2. 外连接抓取(Outer Join Fetching) 3.4.3. 二进制流 (Binary Streams) 3.4.4. 二级缓存与查询缓存 3.4.5. 查询语言中的替换 3.4.6. Hibernate的统计(statistics)机制 3.5. 日志 3.6. 实现NamingStrategy 3.7. XML配置文件 3.8. J2EE应用程序服务器的集成 3.8.1. 事务策略配置 3.8.2. JNDI绑定的SessionFactory 3.8.3. 在JTA环境下使用Current Session context (当前session上下文)管理 3.8.4. JMX部署 4. 持久化类(Persistent Classes) 4.1. 一个简单的POJO例子 4.1.1. 实现一个默认的(即无参数的)构造方法(constructor) 4.1.2. 提供一个标识属性(identifier property)(可选) 4.1.3. 使用非final的类 (可选) 4.1.4. 为持久化字段声明访问器(accessors)和是否可变的标志(mutators)(可选) 4.2. 实现继承(Inheritance) 4.3. 实现equals()和hashCode() 4.4. 动态模型(Dynamic models) 4.5. 元组片断映射(Tuplizers) 5. 对象/关系数据库映射基础(Basic O/R Mapping) 5.1. 映射定义(Mapping declaration) 5.1.1. Doctype 5.1.2. hibernate-mapping 5.1.3. class 5.1.4. id 5.1.4.1. Generator 5.1.4.2. 高/低位算法(Hi/Lo Algorithm) 5.1.4.3. UUID算法(UUID Algorithm ) 5.1.4.4. 标识字段和序列(Identity columns and Sequences) 5.1.4.5. 程序分配的标识符(Assigned Identifiers) 5.1.4.6. 触发器实现的主键生成器(Primary keys assigned by triggers) 5.1.5. composite-id 5.1.6. 鉴别器(discriminator) 5.1.7. 版本(version)(可选) 5.1.8. timestamp (可选) 5.1.9. property 5.1.10. 多对一(many-to-one) 5.1.11. 一对一 5.1.12. 自然ID(natural-id) 5.1.13. 组件(component), 动态组件(dynamic-component) 5.1.14. properties 5.1.15. 子类(subclass) 5.1.16. 连接的子类(joined-subclass) 5.1.17. 联合子类(union-subclass) 5.1.18. 连接(join) 5.1.19. 键(key) 5.1.20. 字段和规则元素(column and formula elements) 5.1.21. 引用(import) 5.1.22. any 5.2. Hibernate 的类型 5.2.1. 实体(Entities)和值(values) 5.2.2. 基本值类型 5.2.3. 自定义值类型 5.3. 多次映射同一个类 5.4. SQL中引号包围的标识符 5.5. 其他元数据(Metadata) 5.5.1. 使用 XDoclet 标记 5.5.2. 使用 JDK 5.0 的注解(Annotation) 5.6. 数据库生成属性(Generated Properties) 5.7. 辅助数据库对象(Auxiliary Database Objects) 6. 集合类(Collections)映射 6.1. 持久化集合类(Persistent collections) 6.2. 集合映射( Collection mappings ) 6.2.1. 集合外键(Collection foreign keys) 6.2.2. 集合元素(Collection elements) 6.2.3. 索引集合类(Indexed collections) 6.2.4. 值集合于多对多关联(Collections of values and many-to-many associations) 6.2.5. 一对多关联(One-to-many Associations) 6.3. 高级集合映射(Advanced collection mappings) 6.3.1. 有序集合(Sorted collections) 6.3.2. 双向关联(Bidirectional associations) 6.3.3. 双向关联,涉及有序集合类 6.3.4. 三重关联(Ternary associations) 6.3.5. 使用<idbag> 6.4. 集合例子(Collection example) 7. 关联关系映射 7.1. 介绍 7.2. 单向关联(Unidirectional associations) 7.2.1. 多对一(many to one) 7.2.2. 一对一(one to one) 7.2.3. 一对多(one to many) 7.3. 使用连接表的单向关联(Unidirectional associations with join tables) 7.3.1. 一对多(one to many) 7.3.2. 多对一(many to one) 7.3.3. 一对一(one to one) 7.3.4. 多对多(many to many) 7.4. 双向关联(Bidirectional associations) 7.4.1. 一对多(one to many) / 多对一(many to one) 7.4.2. 一对一(one to one) 7.5. 使用连接表的双向关联(Bidirectional associations with join tables) 7.5.1. 一对多(one to many) /多对一( many to one) 7.5.2. 一对一(one to one) 7.5.3. 多对多(many to many) 7.6. 更复杂的关联映射 8. 组件(Component)映射 8.1. 依赖对象(Dependent objects) 8.2. 在集合中出现的依赖对象 (Collections of dependent objects) 8.3. 组件作为Map的索引(Components as Map indices ) 8.4. 组件作为联合标识符(Components as composite identifiers) 8.5. 动态组件 (Dynamic components) 9. 继承映射(Inheritance Mappings) 9.1. 三种策略 9.1.1. 每个类分层结构一张表(Table per class hierarchy) 9.1.2. 每个子类一张表(Table per subclass) 9.1.3. 每个子类一张表(Table per subclass),使用辨别标志(Discriminator) 9.1.4. 混合使用“每个类分层结构一张表”和“每个子类一张表” 9.1.5. 每个具体类一张表(Table per concrete class) 9.1.6. Table per concrete class, using implicit polymorphism 9.1.7. 隐式多态和其他继承映射混合使用 9.2. 限制 10. 与对象共事 10.1. Hibernate对象状态(object states) 10.2. 使对象持久化 10.3. 装载对象 10.4. 查询 10.4.1. 执行查询 10.4.1.1. 迭代式获取结果(Iterating results) 10.4.1.2. 返回元组(tuples)的查询 10.4.1.3. 标量(Scalar)结果 10.4.1.4. 绑定参数 10.4.1.5. 分页 10.4.1.6. 可滚动遍历(Scrollable iteration) 10.4.1.7. 外置命名查询(Externalizing named queries) 10.4.2. 过滤集合 10.4.3. 条件查询(Criteria queries) 10.4.4. 使用原生SQL的查询 10.5. 修改持久对象 10.6. 修改脱管(Detached)对象 10.7. 自动状态检测 10.8. 删除持久对象 10.9. 在两个不同数据库间复制对象 10.10. Session刷出(flush) 10.11. 传播性持久化(transitive persistence) 10.12. 使用元数据 11. 事务和并发 11.1. Session和事务范围(transaction scope) 11.1.1. 操作单元(Unit of work) 11.1.2. 长对话 11.1.3. 关注对象标识(Considering object identity) 11.1.4. 常见问题 11.2. 数据库事务声明 11.2.1. 非托管环境 11.2.2. 使用JTA 11.2.3. 异常处理 11.2.4. 事务超时 11.3. 乐观并发控制(Optimistic concurrency control) 11.3.1. 应用程序级别的版本检查(Application version checking) 11.3.2. 扩展周期的session和自动版本化 11.3.3. 脱管对象(deatched object)和自动版本化 11.3.4. 定制自动版本化行为 11.4. 悲观锁定(Pessimistic Locking) 11.5. 连接释放模式(Connection Release Modes) 12. 拦截器与事件(Interceptors and events) 12.1. 拦截器(Interceptors) 12.2. 事件系统(Event system) 12.3. Hibernate的声明式安全机制 13. 批量处理(Batch processing) 13.1. 批量插入(Batch inserts) 13.2. 批量更新(Batch updates) 13.3. StatelessSession (无状态session)接口 13.4. DML(数据操作语言)风格的操作(DML-style operations) 14. HQL: Hibernate查询语言 14.1. 大小写敏感性问题 14.2. from子句 14.3. 关联(Association)与连接(Join) 14.4. join 语法的形式 14.5. select子句 14.6. 聚集函数 14.7. 多态查询 14.8. where子句 14.9. 表达式 14.10. order by子句 14.11. group by子句 14.12. 子查询 14.13. HQL示例 14.14. 批量的UPDATE和DELETE 14.15. 小技巧 & 小窍门 15. 条件查询(Criteria Queries) 15.1. 创建一个Criteria 实例 15.2. 限制结果集内容 15.3. 结果集排序 15.4. 关联 15.5. 动态关联抓取 15.6. 查询示例 15.7. 投影(Projections)、聚合(aggregation)和分组(grouping) 15.8. 离线(detached)查询和子查询 15.9. 根据自然标识查询(Queries by natural identifier) 16. Native SQL查询 16.1. 使用SQLQuery 16.2. 别名和属性引用 16.3. 命名SQL查询 16.3.1. 使用return-property来明确地指定字段/别名 16.3.2. 使用存储过程来查询 16.3.2.1. 使用存储过程的规则和限制 16.4. 定制SQL用来create,update和delete 16.5. 定制装载SQL 17. 过滤数据 17.1. Hibernate 过滤器(filters) 18. XML映射 18.1. 用XML数据进行工作 18.1.1. 指定同时映射XML和类 18.1.2. 只定义XML映射 18.2. XML映射元数据 18.3. 操作XML数据 19. 提升性能 19.1. 抓取策略(Fetching strategies) 19.1.1. 操作延迟加载的关联 19.1.2. 调整抓取策略(Tuning fetch strategies) 19.1.3. 单端关联代理(Single-ended association proxies) 19.1.4. 实例化集合和代理(Initializing collections and proxies) 19.1.5. 使用批量抓取(Using batch fetching) 19.1.6. 使用子查询抓取(Using subselect fetching) 19.1.7. 使用延迟属性抓取(Using lazy property fetching) 19.2. 二级缓存(The Second Level Cache) 19.2.1. 缓存映射(Cache mappings) 19.2.2. 策略:只读缓存(Strategy: read only) 19.2.3. 策略:读/写缓存(Strategy: read/write) 19.2.4. 策略:非严格读/写缓存(Strategy: nonstrict read/write) 19.2.5. 策略:事务缓存(transactional) 19.3. 管理缓存(Managing the caches) 19.4. 查询缓存(The Query Cache) 19.5. 理解集合性能(Understanding Collection performance) 19.5.1. 分类(Taxonomy) 19.5.2. Lists, maps 和sets用于更新效率最高 19.5.3. Bag和list是反向集合类中效率最高的 19.5.4. 一次性删除(One shot delete) 19.6. 监测性能(Monitoring performance) 19.6.1. 监测SessionFactory 19.6.2. 数据记录(Metrics) 20. 工具箱指南 20.1. Schema自动生成(Automatic schema generation) 20.1.1. 对schema定制化(Customizing the schema) 20.1.2. 运行该工具 20.1.3. 属性(Properties) 20.1.4. 使用Ant(Using Ant) 20.1.5. 对schema的增量更新(Incremental schema updates) 20.1.6. 用Ant来增量更新schema(Using Ant for incremental schema updates) 20.1.7. Schema 校验 20.1.8. 使用Ant进行schema校验 21. 示例:父子关系(Parent Child Relationships) 21.1. 关于collections需要注意的一点 21.2. 双向的一对多关系(Bidirectional one-to-many) 21.3. 级联生命周期(Cascading lifecycle) 21.4. 级联与未保存值(Cascades and unsaved-value) 21.5. 结论 22. 示例:Weblog 应用程序 22.1. 持久化类 22.2. Hibernate 映射 22.3. Hibernate 代码 23. 示例:复杂映射实例 23.1. Employer(雇主)/Employee(雇员) 23.2. Author(作家)/Work(作品) 23.3. Customer(客户)/Order(订单)/Product(产品) 23.4. 杂例 23.4.1. "Typed" one-to-one association 23.4.2. Composite key example 23.4.3. 共有组合键属性的多对多(Many-to-many with shared composite key attribute) 23.4.4. Content based discrimination 23.4.5. Associations on alternate keys
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值