gpt4 book ai didi

asp.net-mvc - CQRS中创建聚合根的指导

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

查看 here 中的代码:

[Serializable]
public class CreateClientCommand : Command
{
public string ClientName { get; private set; }
public string Street { get; private set; }
public string StreetNumber { get; private set; }
public string PostalCode { get; private set; }
public string City { get; private set; }
public string PhoneNumber { get; private set; }

public CreateClientCommand(Guid id, string clientName, string street, string streetNumber, string postalCode, string city, string phoneNumber) : base(id)
{
ClientName = clientName;
Street = street;
StreetNumber = streetNumber;
PostalCode = postalCode;
City = city;
PhoneNumber = phoneNumber;
}
}

这里的 Guid 仅与命令相关。它不是(可能)创建的聚合根的 Guid。获取此 Guid 的最佳实践是什么?任何潜在的验证错误如何传达回在总线上放置命令的代码?例如这样:

_bus.Publish(new CreateClientCommand(
Guid.NewGuid(),
_clientDetailsReport.ClientName,
_clientDetailsReport.Street,
_clientDetailsReport.StreetNumber,
_clientDetailsReport.PostalCode,
_clientDetailsReport.City,
_clientDetailsView.PhoneNumber));

_bus.Commit();

据我了解,CQRS通常实现最终一致性。这意味着实际创建客户端可能需要一段时间。一些 MVC/CQRS 代码使用这种方法:

[HttpPost]
public ActionResult Add(DiaryItemDto item)
{
ServiceLocator.CommandBus.Send(new CreateItemCommand(Guid.NewGuid(),item.Title,item.Description,-1,item.From,item.To));

return RedirectToAction("Index");
}

显然,索引页面可能会显示一些包含 DiaryItems 的网格,并且用户可能能够看到最新创建的 DiaryItem(一段时间后可能会出现)。任何反馈将不胜感激。谢谢。

最佳答案

您是否想了解命令本身的 ID 与它可能创建的实体的 ID 之间的区别?前者通常是基础设施问题,可以在消息信封、埋藏在 RPC 协议(protocol)等中找到。后者将是您的域的一部分。 (尽管在许多情况下,最好将实体的 ID 也视为基础设施问题,因为您可能会为了持久性模型中的方便而选择它。)

关于asp.net-mvc - CQRS中创建聚合根的指导,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24383942/

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