我需要对存储在面向文档的数据库(MongoDB)中的(简单)Java对象图进行版本控制。对于关系数据库和Hibernate,我发现了Envers,并且对这种可能性感到非常惊奇。Spring
Data Documents是否可以使用类似的东西?
我发现这篇文章概述了我(以及更多…)关于存储对象版本的想法,并且我当前的实现方式与之相似,因为它将对象的副本存储在带有时间戳的单独的历史记录集中,但是我想改善这一点以节省存储空间。因此,我认为我需要同时对对象树执行“
diff”操作和对旧对象进行重构的“ merge”操作。那里有图书馆对此提供帮助吗?
编辑 :非常感谢与MongoDB和版本控制有关的任何经验!我看到很可能不会有Spring Data解决方案。
我们使用的是基本实体(我们在其中设置ID,创建+上次更改日期,…)。在此基础上,我们使用通用的持久性方法,该方法如下所示:
@Override
public <E extends BaseEntity> ObjectId persist(E entity) {
delta(entity);
mongoDataStore.save(entity);
return entity.getId();
}
delta方法如下所示(我将尝试使其尽可能通用):
protected <E extends BaseEntity> void delta(E newEntity) {
// If the entity is null or has no ID, it hasn't been persisted before,
// so there's no delta to calculate
if ((newEntity == null) || (newEntity.getId() == null)) {
return;
}
// Get the original entity
@SuppressWarnings("unchecked")
E oldEntity = (E) mongoDataStore.get(newEntity.getClass(), newEntity.getId());
// Ensure that the old entity isn't null
if (oldEntity == null) {
LOG.error("Tried to compare and persist null objects - this is not allowed");
return;
}
// Get the current user and ensure it is not null
String email = ...;
// Calculate the difference
// We need to fetch the fields from the parent entity as well as they
// are not automatically fetched
Field[] fields = ArrayUtils.addAll(newEntity.getClass().getDeclaredFields(),
BaseEntity.class.getDeclaredFields());
Object oldField = null;
Object newField = null;
StringBuilder delta = new StringBuilder();
for (Field field : fields) {
field.setAccessible(true); // We need to access private fields
try {
oldField = field.get(oldEntity);
newField = field.get(newEntity);
} catch (IllegalArgumentException e) {
LOG.error("Bad argument given");
e.printStackTrace();
} catch (IllegalAccessException e) {
LOG.error("Could not access the argument");
e.printStackTrace();
}
if ((oldField != newField)
&& (((oldField != null) && !oldField.equals(newField)) || ((newField != null) && !newField
.equals(oldField)))) {
delta.append(field.getName()).append(": [").append(oldField).append("] -> [")
.append(newField).append("] ");
}
}
// Persist the difference
if (delta.length() == 0) {
LOG.warn("The delta is empty - this should not happen");
} else {
DeltaEntity deltaEntity = new DeltaEntity(oldEntity.getClass().toString(),
oldEntity.getId(), oldEntity.getUuid(), email, delta.toString());
mongoDataStore.save(deltaEntity);
}
return;
}
我们的delta实体看起来像这样(没有getters + setters,toString,hashCode和equals):
@Entity(value = "delta", noClassnameStored = true)
public final class DeltaEntity extends BaseEntity {
private static final long serialVersionUID = -2770175650780701908L;
private String entityClass; // Do not call this className as Morphia will
// try to work some magic on this automatically
private ObjectId entityId;
private String entityUuid;
private String userEmail;
private String delta;
public DeltaEntity() {
super();
}
public DeltaEntity(final String entityClass, final ObjectId entityId, final String entityUuid,
final String userEmail, final String delta) {
this();
this.entityClass = entityClass;
this.entityId = entityId;
this.entityUuid = entityUuid;
this.userEmail = userEmail;
this.delta = delta;
}
希望这可以帮助您入门:-)
本章提供了网络 API 的版本控制指南。由于一个 API 服务可能提供多个 API 接口),因此 API 版本控制策略适用于API 接口级别,而不适用于 API 服务)级别。 为了方便起见,术语 API 指的是以下各节中的 API 接口。 网络API应该使用语义化的版本。比如给定版本号 MAJOR.MINOR.PATCH: 当做出不兼容修改的时候,修改 MAJOR 版本号 当以向后兼容的方式添加功
你要为项目做版本控制,学会为项目做版本控制,是开发者的必备技能。用的工具叫 git。 git git 是一种版本控制工具,工具的使用只是一个熟练过程。 https://git-scm.com/ 安装 可以在 git 官网下载适合自己操作系统上用的 git 。也可以使用系统包管理去安装 git,Windows 如果下载了完整版的 cmder ,里面已经包含了 git 。 Windows Window
版本控制 版本管理涉及团队协作,产品质量,和产品上线。使用版本控制工具可使我们自由的做的一些几点: 回退到任意版本 查看历史版本 对比两个版本差异 版本控制系统 版本控制系统(Version Control System)是一种记录若干文件修订记录的系统,它可以帮助开发者查阅或回档至某个历史版本。 手动版本控制 LVCS 本地 CVCS 集中式(例如 SVN) DVCS 分布式(例如 Git) 手
版本控制 软件配置管理, 版本控制的一个组成部分, 也称为校正控制或源码控制, 用于管理文档, 计算机程序, 大型网站和其它信息集合的变化. 变化通常被定义为一串数字或字母代码, 被称为 "版本编号", "版本标识", 或简称"版本". 举个例子, 初始的文件集合是"版本1", 当第一个改变文件时, 就变成了"版本2"等等. 每一个版本都和一个时间戳和做出改变的人联系在一起. 版本可以被比较, 恢
一个版本控制系统(或修订控制系统)是跟踪和控制项目文件变更的技术与实践的组合,包括源代码、文档和网页。如果你以前从来没有使用过版本控制,那你最好赶快找一个有经验的人加入。现今,所有的人都希望你的项目源代码存放在版本控制下,如果不使用版本控制,人们将会轻视项目。 版本控制如此广泛的原因是因为它实际上能帮助运营一个项目的所有方面:内部开发者交流、发布管理、Bug管理、代码稳定性和试验开发投入,以及对某
Webstorm 内置多种版本控制工具支持,下面以最常用的 git 为例,讲解下在 Webstorm 中的版本控制工具的使用。 当 Webstorm 初始化工程时会自动查找与关联项目的版本库。 git的使用 哪里查看当前所处的git分支? 留意界面右下角: 上图表明工程工作目录处于”kf1.3″分支下。 如何新建/查看/切换分支? 从图中可以看到本地分支/远程分支的情况,点击即可切换。 可以点击“