- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图弄清楚如何使用 CQRS/ES 方法处理复杂的域模型。假设我们有例如订单域实体,处理订单的状态和行为。它有一个 Status 属性,带有用于在状态之间切换的转换规则(实现 State pattern 或任何其他类型的状态机)。根据 DDD 原则,这个逻辑应该在 Order 类(代表 Order 模型)本身中实现,具有 approve()
、cancel()
、ship 等方法()
等
看different public examples在这种架构中,事实证明域实体和聚合根是相同的,它处理状态和行为,甚至处理它自己的事件投影。是不是违反了SRP?
但我的问题更具体:如果我想处理新命令(并应用新事件),我是否应该从事件流(即从写入模型和写入数据库)重构实体并调用其行为方法(将事件应用于state) 来处理业务规则?或者只是自己处理命令和事件,没有任何写模型实体?
伪代码说明:
class ApproveOrderHandler
{
private EventStore eventStore
// ...
public void handle(ApproveOrder event)
{
Order order = this.eventStore.findById(event.getOrderId()); // getting order projection from event store
order.approve(); // handling business logic
this.eventStore.save(order.releaseEvents()); // save new events (OrderApproved)
}
}
class Order extends AbstractAggregate
{
private Uuid id;
private DateTime takenAt;
private OrderStatus status;
// ...
public void approve()
{
this.status.approve(); // business rules blah blah
this.Apply(new OrderApproved(this.id)); // applying event
}
// ...
}
是不是有点过头了?
我应该如何处理事件溯源中实体之间的关系?如果它们只存在于“读取模型”中,那么在领域实体类中就没有意义了。
编辑:或者我应该将状态快照存储在“读取数据库”中并从中恢复实体以进行操作?但它打破了“不同的读写模型”的想法......
EDIT2:修复了读/写模型错误
最佳答案
But my question is more concrete: if I want to process new command (and apply new event), should I reconstitute entity from event stream (i.e. from write model and write db) and call its behavioral methods (which applies events to state) to handle business rules?
是的。
Or just handle commands and events themselves, without having any write-model entity?
没有。
命令处理程序位于应用程序组件中;业务模型存在于领域组件中。
保持这些组件分离的动机:使模型更换具有成本效益。领域专家关心的是领域模型,企业在哪里获得胜利。我们不希望编写一次业务模型并使其始终正确——更有可能的是,我们将更多地了解我们希望模型如何工作,从而定期对模型进行改进.因此,用另一个模型替换一个版本的模型不会有太多的拖累——我们希望替换很容易;我们希望做出改变所需的工作量能够反射(reflect)在我们获得的商业值(value)中。
所以我们希望将好东西从“管道”中分离出来。
将所有业务逻辑保留在域组件中会给您带来两个简单的胜利;首先,您不必猜测业务逻辑在哪里——无论用例的细节是简单还是困难,业务逻辑都将在订单中,而不是在其他任何地方。其次,由于业务逻辑不在命令处理程序中,因此您不必担心创建一堆测试替身来满足这些依赖要求——您可以直接针对域模型进行测试。
So, we use handlers to reconstitute entities and calling their business logic methods, NOT to handling business logic itself?
几乎——我们使用 repositories 来重构实体和聚合来处理业务逻辑。命令处理程序的作用是编排;它是 data 模型和 domain 模型之间的粘合剂。
关于architecture - 如何在 DDD + CQRS + Event Sourcing 方法中处理业务规则?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44400402/
当检测鼠标x和y坐标时,最好像这样使用event.clientX和event.clientY: function show_coords(event){ var x=event.clientX;
我有以下代码: document.oncontextmenu = function(evt) { evt = evt || window.event; console.log(evt.
对于另一个问题,我遇到了一个似乎偶尔出现在 SO 的误解。一些提问者似乎认为触发器之于数据库就像事件之于 OOP 一样。 有没有人有一个很好的类比来解释为什么这是一个有缺陷的比较,以及误用它的后果?
$('body').keypress(function(event){ if(event.keyCode == 46){console.log('Delete Key Pressed')};
我正在制作一个“流体”文本区域,它根据内容调整其高度。我实际上正在尝试实现 this脚本。我有以下代码:https://ellie-app.com/Vjtvm6yrKWa1/4 问题是,当增加高度时,
我使用 Raphael .mouseover() 和 .mouseout() 事件来突出显示 SVG 中的某些元素。这工作正常,但在我单击一个元素后,我希望它停止突出显示。 在 Raphael doc
我目前正在开发一个应用程序,允许人们为在线广播电台安排“节目”。 我希望用户能够设置重复事件,例如:- “躁狂星期一”节目 - 每周一 9 点至 11 点“月中疯狂” - 每个月的第二个星期四“本月新
我有以下三个表格(简化版本): 已加载关卡: id(整数、主键、自动增量) globalId(整数,键) 日期(日期时间、键) serverId(Int,键) gamemodeId(Int,Key)
在我阅读 Gevent Tutorial 之后,我有一个关于 gevent.event.Event 的问题。 Event.set() 是否会唤醒所有被 Event.wait() 阻塞的函数? 就像下面
我对 cakephp ver3.1.3 没有经验 我按照说明实现了登录认证功能; http://book.cakephp.org/3.0/en/tutorials-and-examples/blog-
现在,我发送 10 个事件,每个事件有 1 个属性。但是当我想过滤特定事件并按属性选择事件时,在“事件属性”过滤器中仅显示前 7 个事件,而我为其余事件添加的事件仅显示“第一次”过滤器,为什么? 最佳
我不知道我的 Firefox 发生了什么! 我的aspx和javascript代码是这样的: function a() { alert(
中有3个事件fns重装 ,我可以对两者做同样的事情 reg-event-db和 reg-event-fx . reg-event-db之间的主要区别是什么, reg-event-fx和 reg-eve
我遇到了 Firefox keydown 行为,因为在没有聚焦于特定字段的情况下按下 Enter 键(实际上是任何键)不会触发 keydown 事件只会触发`按键事件。 这可能会非常令人困惑,因为 k
这是我的代码片段 public class Notation : INotifyPropertyChanged { public event PropertyChangedEventHandl
我可以在一个 Jsf2 xhtml 文件中有多个标签吗? 在那种情况下,关联的监听器将以什么顺序被调用? Mojarra 2.1.1/Apache Tomcat 7.0.22/PrimeFaces 3
我可以在一个 Jsf2 xhtml 文件中有多个标签吗? 在那种情况下,关联的监听器将以什么顺序被调用? Mojarra 2.1.1/Apache Tomcat 7.0.22/PrimeFaces 3
我有以下 JavaScript: $('#ge-display').click(function (event) { window.open('/googleearth/ge-display.ph
我需要确定触发事件的元素。 使用 event.target 获取相应的元素。 我可以从那里使用哪些属性? 引用 编号 节点名 我找不到关于它的大量信息,即使在 jQuery 上也是如此页,所以希望有人
我在pyGame中创建了一个Asteroidz克隆,并在pygame.vent.get()循环中有两个for Event,一个用于检查退出请求,以及游戏是否应该通过按空格键开始,然后在游戏中进一步尝试
我是一名优秀的程序员,十分优秀!