5

在涉足领域驱动设计时,我遇到了关于如何在我的领域模型中识别聚合根的情况。

我有以下三个类,建模一个简单的待办事项列表:

public class List {
    private IList<Task> _tasks;

    public List() { ... }
    public string Name { get;  set; } }
    public IEnumerable<Task> Tasks() { ... }
    public void AddTask(string descr) { ... }
    public void RemoveTask(Task t) { ... }
    public Task GetRandomTask() { ... }
}

public class Task {
    private IList<Update> _updates;

    public Task(string descr) { ... }

    public string Description { get; }
    public bool IsClosed { get; }
    public IEnumerable<Update> Updates() { ... }
    public void AddUpdate(string descr, bool close) { ... }
}

public class Update {
    public Update(string descr) { ... }
    public string Description { get; }
}

关于模型,我可以说明以下内容:

  1. 更新仅存在于任务的上下文中。
  2. 任务仅存在于列表的上下文中。

因此,列表似乎是唯一的聚合根。(实际上,我的数据访问层只允许加载/保存 List 对象。)但是我看不到如何将我的 Task 类中当前存在的 UI 干净地推送到 List 类。目前我的 List 类正在分发对 Task 对象的引用,允许调用者修改它们。

这是否意味着 Task 也是一个聚合根,即使它的存在依赖于包含列表?

提前致谢。

4

2 回答 2

1

在我看来,在这种情况下你可以有 1 个或 2 个聚合。这完全取决于您在列表中的任务是否很大;以及您的更新是否很大。

如果任务或更新不会增长很多,一个聚合root(List)就可以了。

否则,您可以将它们分成两个聚合root(List, Task)where Listcan addTaskTaskcan add Update

于 2019-03-24T12:15:58.790 回答
0

我认为识别聚合的最佳方法是事件风暴用户故事映射

于 2021-03-16T15:52:19.097 回答