CQRS事件存储聚合与投影

栏目: 数据库 · 发布时间: 5年前

内容简介:投影是事件的视图或表示,因此在聚合表示对我有意义的边界的情况下,而如果聚合包含当前的汇总状态,我会对两者之间的重复感到困惑.翻译自:https://stackoverflow.com/questions/41935619/cqrs-event-store-aggregate-vs-projection

投影是事件的视图或表示,因此在聚合表示对我有意义的边界的情况下,而如果聚合包含当前的汇总状态,我会对两者之间的重复感到困惑.

In a CQRS event store, does an “aggregate” contain a summarized view of the events or simply a reference to the boundary of those events? (group id)

事件存储中不存在聚合

>活动现场直播

>聚合生活在写模型中(CQRS的C)

在这种情况下,Aggregate仍具有与 “Blue Book” 中相同的基本含义;它是围绕一个或多个实体的边界的术语,这些实体彼此立即一致.聚合的责任是确保对记录簿的写入(命令)尊重业务不变量.

在事件存储中,通常方便地将事件组织成“流”;如果您想象一个 RDBMS schema ,则流ID将只是一些标识符,表示“这些事件都是同一历史记录的一部分”.

通常情况是一个聚合 – >一条小溪,但通常并不总是;在更改模型时,您可能需要处理一些特殊情况. Greg Young在他的新 eBook on event versioning 中报道了其中一些.

So it’s possible that the same data structure might exist in the aggregate and query side store (duplicated view used for different purposes). 

是的,不.绝对是在验证写入时使用的数据结构与用于支持查询的数据结构匹配的情况.但存储通常不匹配.换句话说,聚合不会被存储(聚合的状态);然而,查询视图被缓存(相反,不是数据结构本身,而是可用于重新填充数据结构而无需重放所有事件的表示)是相当普遍的.

Any chance you have an example of aggregate state data structure (rdbms)? Every example I’ve found is trimmed down to a few columns with something like include id, source_id, version making it difficult to visualize what the scope of an aggregate is

一个常见的例子是交易账户(负责匹配“买入”和“卖出”订单的汇总).

在传统的RDBMS商店中,它可能看起来像书籍表中的一行,具有书籍的唯一ID,关于该书正在跟踪的项目的信息,关于该书何时活动的日期信息,等等.此外,可能存在某种订单表,包括uniq id,交易账户ID,订单类型,交易编号,价格和交易量(换句话说,汇总需要知道的所有信息以满足其不变量) .

在文档存储中,您可以在单个文档中看到所有这些信息 – 可能是包含有关根对象信息的json文档,以及两个订单对象列表(一个用于购买,一个用于销售).

在事件存储中,您将看到单个OrderPlaced,TradeOccurred,OrderCancelled.

it seems that the aggregate is computed using the entire set of events unless it gets large enough to warrant a snapshot.

是的,这是完全正确的.如果您熟悉“折叠功能”,那么事件采购只是一些常见初始状态的折叠.当快照可用时,我们将从该状态折叠(相应减少折叠的事件数)

在具有“快照”的事件源环境中,您可能会看到事件存储和文档存储的组合(其中文档将包含指示事件流在何处组装的其他元信息).

翻译自:https://stackoverflow.com/questions/41935619/cqrs-event-store-aggregate-vs-projection


以上所述就是小编给大家介绍的《CQRS事件存储聚合与投影》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Ajax Design Patterns

Ajax Design Patterns

Michael Mahemoff / O'Reilly Media / 2006-06-29 / USD 44.99

Ajax, or Asynchronous JavaScript and XML, exploded onto the scene in the spring of 2005 and remains the hottest story among web developers. With its rich combination of technologies, Ajax provides a s......一起来看看 《Ajax Design Patterns》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

html转js在线工具
html转js在线工具

html转js在线工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具