Spring ORM 简介
Spring 框架支持与 Java Persistence API (JPA) 集成,并支持原生的 Hibernate 进行资源管理、数据访问对象 (DAO) 实现和事务策略。例如,对于 Hibernate,通过几个方便的 IoC 特性提供了一流的支持,解决了许多典型的 Hibernate 集成问题。你可以通过依赖注入配置所有支持的对象关系 (OR) 映射工具的特性。它们可以参与 Spring 的资源和事务管理,并且符合 Spring 通用的事务和 DAO 异常层次结构。推荐的集成方式是针对纯 Hibernate 或 JPA API 编写 DAO。
当您创建数据访问应用程序时,Spring 为您选择的 ORM 层增加了显著的增强功能。您可以根据需要利用尽可能多的集成支持,并且应该将这种集成工作与内部构建类似基础设施的成本和风险进行比较。您可以将大部分 ORM 支持作为库使用,无论技术如何,因为所有内容都设计为一组可重用的 JavaBeans。Spring IoC 容器中的 ORM 有助于配置和部署。因此,本节中的大多数示例都展示了 Spring 容器内的配置。
使用 Spring Framework 创建 ORM DAO 的好处包括:
-
更简单的测试。Spring 的 IoC 方法使得交换 Hibernate
SessionFactory实例、JDBCDataSource实例、事务管理器和映射对象实现(如果需要)的实现和配置位置变得容易。这反过来又使得单独测试每个与持久性相关的代码片段变得容易得多。 -
通用数据访问异常。Spring 可以封装来自 ORM 工具的异常,将它们从专有(可能是受检)异常转换为通用的运行时
DataAccessException层次结构。此功能让您可以在适当的层中处理大多数持久性异常(这些异常是不可恢复的),而无需烦人的样板捕获、抛出和异常声明。您仍然可以根据需要捕获和处理异常。请记住,JDBC 异常(包括特定于数据库的方言)也会转换为相同的层次结构,这意味着您可以在一致的编程模型中执行一些 JDBC 操作。 -
通用资源管理。Spring 应用程序上下文可以处理 Hibernate
SessionFactory实例、JPAEntityManagerFactory实例、JDBCDataSource实例和其他相关资源的位置和配置。这使得这些值易于管理和更改。Spring 提供高效、简便和安全的持久化资源处理。例如,使用 Hibernate 的相关代码通常需要使用相同的 HibernateSession来确保效率和正确的事务处理。Spring 通过 HibernateSessionFactory公开当前Session,使其能够轻松地透明地创建Session并将其绑定到当前线程。因此,Spring 解决了典型 Hibernate 使用中的许多长期存在的问题,适用于任何本地或 JTA 事务环境。 -
集成事务管理。您可以通过
@Transactional注解或在 XML 配置文件中显式配置事务 AOP 建议,将 ORM 代码包装在声明式、面向切面编程 (AOP) 风格的方法拦截器中。在这两种情况下,事务语义和异常处理(回滚等)都由您处理。如资源和事务管理中所述,您还可以交换各种事务管理器,而不会影响您的 ORM 相关代码。例如,您可以在本地事务和 JTA 之间进行切换,并且在这两种情况下都提供相同的完整服务(例如声明式事务)。此外,JDBC 相关代码可以与您用于 ORM 的代码完全集成到事务中。这对于不适合 ORM 的数据访问(例如批处理和 BLOB 流)但仍需要与 ORM 操作共享通用事务的情况非常有用。
| 为了获得更全面的 ORM 支持,包括对 MongoDB 等替代数据库技术的支持,您可能需要查看 Spring Data 项目套件。如果您是 JPA 用户,spring.io 上的 Getting Started Accessing Data with JPA 指南提供了一个很好的入门介绍。 |