假设我想创建一个行动网站,成员可以在其中竞标项目。为了对这个域建模,我有三个类:Member、Item 和 Bid。我的头脑风暴会是这样的:
- 项目可以包含多个出价
- 出价与一个项目和一个成员相关联
- 成员可以包含多个出价
- Member 和 Item 可以在没有出价实例的情况下存在
- 没有 Member 和 Item 的投标实例不能存在
考虑到这一切,很明显,由于 Member 和 Item 对象是独立的,我们可以将它们视为聚合根。投标将是这些总和之一的一部分。这很清楚,但现在让我感到困惑的是我应该选择哪个聚合根?项目或成员?
这是 Apress 的 Pro ASP.NET MVC 3 Framework 书中的示例,他们的做法如下:
这给出了以下代码:
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 中。现在假设我有应用程序用例:“获取特定成员发布的所有出价”。这是否意味着我必须首先获取所有项目(例如,通过存储库接口从数据库中获取),然后枚举每个项目的所有投标以试图找到匹配的成员?是不是有点低效?因此,更好的方法是在 Member 内部聚合 Bid 对象。但在这种情况下,请考虑新的用例:“获取特定项目的所有投标”。现在我们又需要换一种方式来获得所有的出价......
所以考虑到我需要在我的应用程序中实现这两个用例,那么对这个域建模的正确和有效的方法是什么?