Spring ORM 简介

Spring Framework 支持与 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 实例、JDBC DataSource 实例、事务管理器和映射对象实现(如果需要)的实现和 配置位置。这反过来使得隔离测试每个与持久性相关的代码片段变得更加容易。

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

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

  • 集成事务管理。 你可以通过 @Transactional 注解或通过在 XML 配置文件中 显式配置事务 AOP 建议,使用声明式、面向切面编程 (AOP) 风格的方法拦截器来包装 你的 ORM 代码。在这两种情况下,事务语义和异常处理(回滚等)都由你处理。如 资源和事务管理 中所述,你还可以切换各种事务管理器,而不会影响你的 ORM 相关代码。例如,你可以在 本地事务和 JTA 之间切换,在两种情况下都提供相同的完整服务(例如声明式事务)。 此外,JDBC 相关代码可以与你用于 ORM 的代码进行完全事务集成。这对于不适合 ORM (例如批处理和 BLOB 流式传输)但仍需要与 ORM 操作共享通用事务的数据访问很有用。

为了获得更全面的 ORM 支持,包括对 MongoDB 等替代数据库技术的支持,你可能需要 查看 Spring Data 项目套件。如果你是 JPA 用户, Spring Data JPA 入门 指南 来自 [role="bare"][role="bare"][role="bare"]https://spring.io 提供了一个很好的介绍。