java - 使用JPA手动控制数据库更新

标签 java jpa entitymanager

我正在考虑在应用程序中使用 JPA 来保存多个对象。

尽管如此,应用程序的使用似乎并不符合标准 JPA 方法来更新对象的每次更改。

应用程序的使用情况是一次只有几百个对象处于 Activity 状态,但这些对象每秒都会更新几次。

虽然应用程序在内存中拥有对象,但不需要不断更新数据库中的对象,这只是无用的 IO。

是否可以使用 JPA 在 session 中加载一些对象,并且在不影响其他实体管理对象的情况下,在内存中对它们进行几分钟的更改,然后更新数据库?

如果有一种方法可以在 session 之间共享某些对象来实现此目的,那将是非常有帮助的。

最佳答案

如果您不希望对实体进行任何数据库更改,只需将它们与实体管理器分离即可。

  1. 要在事务期间将对象与实体管理器分离,只需使用 detach方法。
  2. 如果实体不受管理(即事务关闭后),则该实体无论如何都不受管理,您无需额外代码即可对其进行任何更改。

JPA 2.0 规范的摘录,介绍实体如何分离:

A detached entity results from transaction commit if a transaction-scoped container-managed entity manager is used (see section 3.3); from transaction rollback (see section 3.3.2); from detaching the entity from the persistence context; from clearing the persistence context; from closing an entity man- ager; or from serializing an entity or otherwise passing an entity by value—e.g., to a separate applica- tion tier, through a remote interface, etc.

然后,当决​​定对数据库进行更改时,您只需合并分离的实体:entityManager.merge(entity);

我认为,您错过了一些 JPA 背景,例如实体的状态是什么以及entityManager 的操作是什么。我建议要么搜索一些教程,要么阅读 JPA spec 中的一些章节。 (阅读第3.2章实体实例的生命周期 ,大约5页,我保证你会明白很多)。另外,如果您希望 MERGE 操作级联,JPA 中也有一个解决方案。 对于 EntityManager 上的操作以及 JPA 中的良好介绍:the official tutorial .

更新 我将尝试简短地向您描述这些教程中重要的内容。

如果实体实例(即持久性 Java 对象)与持久性上下文(~ EntityManager)相关联,则它是受管理的。如果它是托管的,那么它的更改会被跟踪,这意味着更改托管实体实例将同步到数据库。更改会同步到数据库,例如当事务完成或调用 entityManager.flush() 时(请阅读第 3.2.4 节“同步到数据库”以获取更多详细信息)。

合并操作实际上是更新和持久化实体实例 E1 的操作。它返回一个托管实体实例 E2,而传递的实体 E1 仍然不受管理。

另一侧的分离实体不会被entityManager跟踪,这意味着entityManager不会看到您所做的更改,直到您不合并该实体.

这两个操作(还有一个持久操作,我没有讨论)都是切换实体实例管理<->分离状态的方法。

现在与您有关 root&children 的问题相关:如果未配置任何内容,在您的 root 上调用 merge()detach() 不会影响您的 child 。但是您可以在 JPA 中使用级联方案,例如,调用 entityManager.merge(root) 也会在其子级上调用。当然,由您决定哪些操作级联,哪些不级联。

关于java - 使用JPA手动控制数据库更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20166859/

相关文章:

java - 什么方法签名适合返回通用对象?

java - 坚持尝试对并行数组进行排序

java - 如何解决类中出现的一对多循环?

java - 在 Ice Cream Sandwich 中移动 Android 状态栏

java - jProgressBar 与数据库

java - 如何使用 hibernate 更新实体

java - JPA 标准多对多加入还是不加入?

java - 如何更改此查询以使其返回满足 `minPrice` 条件的记录,即使 `keywords` 值为空?

java - EntityManager.flush 有什么作用,为什么需要使用它?