Introduction to ORM with Spring

Spring Framework 1 支持与 Java 持久 API (JPA) 集成,并支持本地 Hibernate 进行资源管理、数据访问对象 (DAO) 实现和事务策略。例如,对于 Hibernate,它享有头等公民支持,并具有多个方便的 IoC 特性,这些特性解决了众多典型的 Hibernate 集成问题。你可以通过依赖注入配置所有受支持的 OR(对象关系)映射工具的特性。它们可以参与 Spring 的资源和事务管理,并且遵守 Spring 的通用事务和 DAO 异常层次结构。建议的集成风格是根据纯 Hibernate 或 JPA API 编写 DAO。

当你创建数据访问程序时,Spring 会显著增强你选择中的 ORM 层。你可以根据需要利用大量集成支持,并且你应该将这个集成工作与内部构建类似基础设施的成本和风险进行比较。你可以将大量 ORM 支持用作库,无论采用什么技术,因为所有内容都设计为一组可重用的 JavaBean。Spring IoC 容器中的 ORM 方便了配置和部署。因此,本节中的大多数示例都显示了 Spring 容器内的配置。

使用 Spring Framework 创建 ORM DAO 的好处包括:

  • Easier testing. Spring 的 IoC 方法可以很容易地交换 Hibernate SessionFactory 实例、JDBC DataSource 实例、事务管理器和映射对象实现(如果需要)的实现和配置位置。而这反过来又使得更加容易单独测试每段与持久性相关的代码。

  • Common data access exceptions. Spring 可以封装 ORM 工具抛出的异常,将它们从专有(可能是已检查)异常转换为一个通用的运行时 DataAccessException 层次结构。此功能允许您仅在适当的层中处理大多数不可恢复的持久性异常,而无需烦人的样板化 catch、throws 和异常声明。您仍然可以根据需要捕捉并处理异常。请记住,JDBC 异常(包括特定于数据库的方言)也会转换为相同的层次结构,这意味着您可以在一致编程模型中使用 JDBC 执行一些操作。

  • General resource management. Spring 应用程序上下文可以处理 Hibernate SessionFactory 实例、JPA EntityManagerFactory 实例、JDBC DataSource 实例和其他相关资源的位置和配置。这使得管理和更改这些值变得很容易。Spring 提供了持久性资源的高效、简单且安全的处理方法。例如,通常使用 Hibernate 的相关代码需要使用同一个 Hibernate Session 来确保效率和正确的交易处理。Spring 可以轻松地创建 Session 并将其透明地绑定到当前线程,通过 Hibernate SessionFactory 公开当前 Session。因此,Spring 解决了许多典型的 Hibernate 使用中的长期问题,适用于任何本地或 JTA 交易环境。

  • Integrated transaction management. 您可以通过 @Transactional 注释或在 XML 配置文件中明确配置事务 AOP 建议,使用声明性面向切面编程 (AOP) 样式方法拦截器,封送您的 ORM 代码。在这两种情况下,都会为您处理事务语义和异常处理(回滚等)。正如 Resource and Transaction Management 中讨论的那样,您还可以交换各种事务管理器,而不会影响您相关的 ORM 代码。例如,您可以在本地事务和 JTA 之间进行交换,并且在两种情况下都提供相同的完整服务(如声明性事务)。此外,与 JDBC 相关的代码可以与您用于执行 ORM 的代码完全集成。这对于不适合 ORM 的数据访问(如批量处理和 BLOB 流处理)很有用,但仍需要与 ORM 操作共享公共事务。

关于更全面的 ORM 支持,包括对 MongoDB 等替代数据库技术的支持,您可以查看 Spring Data 项目套件。如果您是 JPA 用户,则 [role="bare"][role="bare"]https://spring.io 中的 使用 JPA 访问数据的入门指南 提供了一个不错的介绍。