gpt4 book ai didi

domain-driven-design - DDD : Modeling simple domain with two aggregate roots

转载 作者:行者123 更新时间:2023-12-02 22:38:38 24 4
gpt4 key购买 nike

假设我想创建一个成员(member)可以为元素出价的行动网站。为了对这个领域建模,我使用了三个类:Member、Item 和 Bid。我的头脑 Storm 会是这样的:

  • 项目可以包含多个出价
  • 出价与一个项目和一个成员相关联
  • 成员可以包含多个出价
  • Member 和 Item 可以在没有 bid 实例的情况下存在
  • 如果没有 Member 和 Item,则不能存在 Bid 实例

考虑到所有这些,很明显,由于 Member 和 Item 对象是独立的,我们可以将它们视为聚合根。出价将是这些汇总之一的一部分。这很清楚,但现在令我困惑的是我应该选择哪个聚合根?项目或成员?

这是 Apress 的 Pro ASP.NET MVC 3 Framework 一书中的例子,他们的做法如下:

enter image description here

给出以下代码:

public class Member 
{
public string LoginName { get; set; } // The unique key
public int ReputationPoints { get; set; }
}

public class Item
{
public int ItemID { get; private set; } // The unique key
public string Title { get; set; }
public string Description { get; set; }
public DateTime AuctionEndDate { get; set; }
public IList<Bid> Bids { get; set; }
}

public class Bid
{
public Member Member { get; set; }
public DateTime DatePlaced { get; set; }
public decimal BidAmount { get; set; }
}

Member 和 Item 是这里的聚合根,Bid 包含在 Item 中。现在假设我有应用程序用例:“获取特定成员发布的所有出价”。这是否意味着我必须首先获取所有项目(例如,通过存储库接口(interface)从数据库中获取),然后枚举每个项目的所有出价以尝试找到匹配的成员?这不是有点低效吗?因此,更好的方法是在 Member 中聚合 Bid 对象。但在那种情况下,请考虑新的用例:“获取特定项目的所有出价”。现在我们又需要另辟蹊径来获得所有出价...

因此,考虑到我需要在我的应用程序中实现这两个用例,那么对这个领域建模的正确且有效的方法是什么?

最佳答案

您的域实际上应该仅反射(reflect)命令 (CQRS) 要求(更新/更改数据)。我假设您需要查询(读取数据,不更新/更改数据):“获取特定项目的所有出价”和“获取特定成员发布的所有出价”。因此,此“查询”与域无关,因为查询实现独立于命令实现(命令正在调用域方法)。这使您可以自由地以高效的方式实现每个查询。我的方法是实现一个高效的数据库 View ,让您只获取想要在 UI 中显示的数据。然后创建一个名为 BidForItemDto (DTO = data transfer object) 的新类,并将数据从 DB View 映射到 BidForItemDto 的集合中(您可以通过 ADO.NET 手动完成或使用 NHibernate(首选,为您完成一切))。与第二个查询相同,创建一个名为 BidPostedByMemberDto 的新类。

因此,如果您需要的是查询,只需忘记域,意识到它只是您想要在 UI 中显示的数据,并从数据库中高效地查询它们。只有当您在 UI 中执行某些操作(例如单击按钮进行出价)时,它才会执行“出价”命令,这将在最后调用域方法 Item.PlaceBid(Member member, DateTime date, decimal amount ).顺便说一句,恕我直言,它是一个“有很多出价”的项目,而域方法“出价”肯定需要访问以前的出价才能正确实现整个逻辑。将出价收集放入 Member 对我来说没有多大意义......

从我的脑海中浮现出一些数据库 View 和 sql 查询的例子:

获取特定项目的所有出价:

create view BidForItemDto
as
select
i.ItemId,
b.BidId,
b.MemberId,
b.DatePlaced,
b.BidAmount
from Item i
join Bid b ON b.ItemId = i.ItemId

查询:

SELECT *
from BidFormItemDto
where ItemId = <provide item id>

获取特定成员发布的所有出价:

create view BidPostedByMemberDto
as
select
m.MemberId,
b.BidId,
b.MemberId,
b.DatePlaced,
b.BidAmount
from Member m
join Bid b ON b.MemberId = i.MemberId

查询:

SELECT *
from BidPostedByMemberDto
where MemberId = <provide member id>

关于domain-driven-design - DDD : Modeling simple domain with two aggregate roots,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11065834/

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