版本化 JPA 实体

  • Craig Wickesser
  • 张龙

2008 年 8 月 4 日

话题:JavaDevOps语言 & 开发架构

EnversJBoss的一个开源项目,最近它发布了 1.0.0 GA 版,在 Envers 的网站上这样阐述其自身的目标:
。。。简化持久性 JPA 类的版本化工作。若要对类或属性进行版本管理,只需在对应的类和属性上添加 @Versioned 注解即可。对于每个版本实体,都有一张表与之相对应,这张表记录了实体所有的更改历史。这样一来,读取或查询历史数据就变得不费吹灰之力。
由于 Envers 与 Hibernate 及 Hibernate Entity Manager 兼容,Hibernate 能运行的地方,Envers 就能运行。例如,Envers 可以独立运行,也可以在应用服务器中运行,还能与 JBoss Seam以及Spring协同工作。Envers 的当前版本提供的诸多特性中包括:
  • 对基本属性(strings, integers, longs...)的版本管理
  • 对基本属性构成的嵌入式组件的版本管理
  • 使用简单的、合成或嵌入式 id 对类进行版本管理
  • 对一对一单向或双向关联关系进行版本管理(单向关系中只针对关系主体的拥有者进行版本管理)
  • 对一对多单向或双向关联关系进行版本化(单向关系中只针对关系主体的拥有者进行版本管理)
  • 支持次级表(secondary tables)
  • 使用“修订实体(revision entity)”跟踪记录每个修订版本
  • 查询历史数据
尤其出色的是,1.0.0 GA 版对集合的变化也提供了修订版本管理,之前的预览版与 beta 版中都没有这项功能,例如
假设你有一个 Person 实体和一个 Address 实体,他们为双向多对一关系(每个人只有一个地址,几个人可以拥有相同的地址)。现在修改其中某个人的地址,那么新、旧地址所对应的 persons 集合的内容就发生了变化。之前的预览版与 beta 版都不会为 Addresses(只针对 Person)做修订版本管理,原因是数据库中的数据并没有发生变化(发生变化的是 java beans 中的数据)。而现在,所有这三个实体来会有产生一个修订版本而记录在更改历史中。
如果出于某种原因需要关闭这个功能的话,只需要按下列代码修改一下配置就可以了:

在未来的版本中,Envers 会支持对任何类型关联的版本管理,不再只局限于一对一或一对多。而且,它将只存储版本间差异,来达到节省空间的目的等等。Envers 是一个相当新的项目,目前尚还没引起广泛“追捧”,但它非常值得大家关注。以下资源可以帮助你进一步了解 Envers 的相关信息:

查看英文原文:Versioning JPA Entities

JavaDevOps语言 & 开发架构