DDD - 仅在更改时保留聚合子项

DDD - persisting aggregate children only if changed

我正在尝试在我目前正在处理的应用程序中使用 DDD。 我有以下 UserAggregate 结构:

UserAggregate
- ProfileEntity
- ImageEntity
- RatingEntity

我有一个 UserRepository,它正在查询实体映射器以构建 UserAggregate。

现在我想将 UserAggregate 传递给 UserRepository 以实现持久性,例如 UserRepository->save(UserAggregate)。我如何告诉 UserRepository UserAggregate 子实体已更改并需要保存?有什么共同的模式吗?我知道 UintOfWork 模式,但无法真正想象它对儿童有何帮助,因为 我只想在子实体实际更改时才访问映射器(和数据库).

有什么方法可以跟踪实体对象的 "dirty state",特别是在 PHP 中?还是我错过了聚合根和存储库的概念?

基本上有两种解决该问题的方法。您可以使用 快照比较 基于代理的更改跟踪 。它们都有优点和缺点。选择还取决于您使用的库,因为它们可能支持其中之一。

在这里,我描述了基本方法。我不知道您具体使用的是什么库,因此这将帮助您 select 制定策略并评估库。

基本设计注意事项

这两种策略都是持久性机制的职责,不得泄漏到域和应用程序逻辑中。换句话说,它们必须对存储库的用户和域对象透明。

快照比较

使用此策略,您可以在通过存储库加载聚合时保留聚合数据的快照。稍后,当可能已修改的聚合再次通过 Update 调用传递给存储库时,您将遍历聚合以确定其中的数据是否已更改。

基于代理的更改跟踪

使用此策略,您 return 一个代理真实聚合而不是聚合本身的对象。当通过存储库加载聚合时,将创建代理并用于包装聚合。

代理对聚合上的读取操作不执行任何操作,但会在调用变异操作时设置脏标志。当(代理的)聚合被传递到存储库以进行持久化时,您只需检查脏标志。