gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 17:40:27 26 4
gpt4 key购买 nike

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

我有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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com