domain-driven-design - DDD : Aggregate design - Referencing between aggregates

标签 domain-driven-design repository-pattern unit-of-work aggregateroot onion-architecture

我对如何设计聚合有疑问。

我有Company , City , ProvinceCountry实体。其中每一个都需要是其自身聚合的聚合根。 City , ProvinceCountry实体在整个系统中使用,并被许多其他实体引用,因此它们不是值对象,也需要在许多不同的场景中访问。所以他们应该有存储库。 CityRepository会有类似 FindById(int) 的方法, GetAll() , GetByProvince(Province) , GetByCountry(Country) , GetByName(string) .

举个例子。 Company实体与 City 相关联, 属于 Province属于 Country :

Aggregate Roots

现在假设我们有一个公司列表页面,其中列出了一些公司及其城市、省份和国家/地区。

ID 引用

如果实体需要引用 City , ProvinceCountry ,他们会通过 ID 这样做(正如 Vaughn Vernon 所建议的那样)。

为了从存储库中获取这些数据,我们需要调用 4 个不同的存储库,然后匹配数据以填充 View 。

var companies = CompanyRepository.GetBySomeCriteria();
var cities = CityRepository.GetByIds(companies.Select(x => x.CityId);
var provinces = ProvinceRepository.GetByIds(cities.Select(x => x.ProvinceId);
var countries = CountryRepository.GetByIds(province.Select(x => x.CountryId);

foreach(var company in companies)
{
    var city = cities.Single(x => x.CityId == company.CityId);
    var province = provinces.Single(x => x.ProvinceId == city.ProvinceId);
    var country = countries.Single(x => x.CountryId == province.CountryId);

    someViewModel = new CompanyLineViewModel(company.Name, city.Name, province.Name, country.Name);
}

这是一种非常笨重且效率低下但显然是“正确”的方式?

引用引用

如果实体是通过引用引用的,则相同的查询将如下所示:

var companies = CompanyRepository.GetBySomeCriteria();
someViewModel = new CompanyLineViewModel(company.Name, company.City.Name, company.Province.Name, company.Country.Name);

但据我了解,这些实体不能通过引用来引用,因为它们存在于不同的聚合中。

问题

我还能如何更好地设计这些聚合?

我能否使用城市模型加载公司实体,即使它们存在于不同的聚合体中?我想这很快就会打破聚合之间的界限。在更新聚合时处理事务一致性时,它也会造成混淆。

最佳答案

您可以创建一个完全不同的对象(它只是一个平面数据结构)来表示 View 模型并且可以直接从数据库中检索。谷歌“薄读取层”或“CQRS”。

关于domain-driven-design - DDD : Aggregate design - Referencing between aggregates,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21480699/

相关文章:

domain-driven-design - 领域驱动设计 - 如何处理部分聚合根的更新

c# - 使用 EF Core 将 SQL 转换为 Linq

asp.net-mvc-2 - ASP.NET MVC - 我想我做错了

asp.net-mvc - 在 ASP.NET MVC 中实现存储库模式

java - 为什么术语 "unit of work"如此重要,为什么 JDBC AutoCommit 违反了这个模式?

repository - 用于多个存储库的重要 CRUD 操作的工作单元

domain-driven-design - 事件溯源、CQRS、DDD : One-to-Many relationship

c# - 如何使用 MVC 清理和验证 ViewModel?

domain-driven-design - DDD/CQRS/ES 使用图形数据库实现聚合成员,也就是使用立即一致的 readModel 作为实体集合

domain-driven-design - 标准值类型作为 DDD 中的 ValueObjects?