13

我正在开发一个使用 Hibernate 4.1、Spring 3.1 和 JPA 2.0 的项目,我想验证我从互联网上收集到的内容是否正确。

我正在尝试决定是使用 JPA entityManager 还是特定于休眠的 sessionFactory。

起初,我计划使用 entityManager 和完整的 JPA 规范,这样我的项目将与 Hibernate 分离,如果后来有什么想法让我信服,我可以把它换成其他东西,比如 EclipseLink。

但是,entityManager 似乎有一些非常重要的限制。

我的问题:

我想要使​​用完整的 JPA 规范和 entityManager 的唯一原因是能够相对轻松地为不同的 JPA 2.0 兼容 ORM 切换 Hibernate,对吗?使用 entityManager 真的没有性能/功能/易于编程的好处吗?

其次,似乎休眠 sessionFactory 比 entityManager 有很多好处。到目前为止,我遇到了 entityManager 无法执行实体列表的批量插入的问题,我读过 sessionFactory 可以。我还读到 sessionFactory 可以自动返回自动生成的实体 ID,而使用 entityManager 您需要结束事务/刷新持久性上下文以提取新生成的 ID。

我喜欢我的项目与 Hibernate 相对分离的想法,但我更希望能够从一开始就编写高效的数据库更新。所以我应该切换到为 hibernate 和 sessionFactory 配置的项目,对吗?

4

2 回答 2

11

我会坚持使用 JPA2,就像您使用的那样,List而不是ArrayList:您更喜欢接口(或抽象)而不是实现。除了 HQL 知道比 JPQL 或外来特性“更多”的东西之外,没有太大区别。还要记住 JPA 是在 Hibernate 之后制作的,而 Hibernate 是 JPA 背后的“灵感”。

对于奇异的特性:Hibernate Entity Manager 包装一个 Hibernate Session。如果您真的需要它们,您可以将EntityManager转换为 Hibernate 接口 ( org.hibernate.jpa.HibernateEntityManager),并使用该会话。但如果我说我试过了,那我就是在骗你。

我还评论了您的部分问题:

我想要使​​用完整的 JPA 规范和 entityManager 的唯一原因是能够相对轻松地为不同的 JPA 2.0 兼容 ORM 切换 Hibernate,对吗?使用 entityManager 真的没有性能/功能/易于编程的好处吗?

从 Hibernate 切换到 EclipseLink 并不意味着您“只需要交换 jar”。映射和注释解析不一样,您会遇到可能会阻止您切换的问题。

您可以在此处阅读我的问题,了解我在使用两者时遇到的问题示例(这是一个 maven 项目,其配置文件可将 JPA2.1 impl 从 EclipseLink 切换到 Hibernate)。我放弃了 EclipseLink,因为我无法像我想要的那样命名数据库对象(或者更确切地说,指定数据库对象的名称)。

其次,似乎休眠 sessionFactory 比 entityManager 有很多好处。到目前为止,我遇到了 entityManager 无法执行实体列表的批量插入的问题,我读过 sessionFactory 可以。我还读到 sessionFactory 可以自动返回自动生成的实体 ID,而使用 entityManager 您需要结束事务/刷新持久性上下文以提取新生成的 ID。

这取决于您如何生成实体 ID。但是想一想:在持久化上下文需要持久化它之前,您的实体不会持久化。这就是你没有身份证的原因。刷新它,也就是发送带有生成 id 的插入查询,是唯一的方法。

这同样适用于会话工厂。

但是,您可能能够从 Hibernate 访问序列生成器,但您也可以在本机 SQL 中使用EntityManager.

我喜欢我的项目与 Hibernate 相对分离的想法,但我更希望能够从一开始就编写高效的数据库更新。所以我应该切换到为 hibernate 和 sessionFactory 配置的项目,对吗?

您可以将其视为针对 ORM 的巨魔,但为了高效的数据库更新,请使用普通 JDBC(或 Spring Jdbc 模板)。至少您会知道数据何时会更新,并且您将能够更好地优化(批量更新等)。

于 2014-09-13T00:45:35.407 回答
2

JPA 是 Hibernate 上的一个接口,它是 jdbc 上的一个接口,因此您离 jdbc 越近,您对查询的控制就越多,但您离对象/关系持久性越远。是的,Hibernate 可能有一些 jpa 目前可能无法提供的工具(即 hibernate 空间) Hibernate 很有趣,并且可以使用 JPA 注释来映射域模型(如果您在 .hbm 文件上使用注释方式)。@Transactional 注释在 Spring 中的工作方式无论您使用 hibernate 还是 jpa 都无关紧要,因为您不需要 session.open() ... session.beginTranscation ...session.close ...etc ...所有这些冗长休眠代码不见了!有关于 Hibernate 的很棒的文档和很棒的书籍。至于 JPA,我不能说我找到了 umber 书……

于 2013-09-19T11:07:21.753 回答