使用Nhibernate过滤使用Aggregate Root返回的子集合

5 c# nhibernate

我正在尝试使用Nhibernate加载聚合根的子集合.向客户加载已发货的所有订单.这可能吗?

Tim*_*ott 3

那么,您可以公开在地图中过滤的属性,如下所示:

<bag name="shippedOrders" ... where="Status == 'Shipped'" >
   <key column="CustomerId" />
   <one-to-many class="Order" />
</bag>
Run Code Online (Sandbox Code Playgroud)

“where”属性是任意 SQL。

理论上,您可以拥有 Customer、Orders 和 ShippedOrders 两个属性。不过,我应该说我还没有这样做,我想测试 NH 在这种情况下如何处理级联。无论如何,当添加/删除新项目时,您必须注意确保它们正确添加/删除到两个集合中。

您想要这样做的事实让我们想知道 Order 是否是聚合根。从长远来看,这样做可能会少一些麻烦:

orderRepository.GetOrders(int customerId, OrderStatus[] statuses)
Run Code Online (Sandbox Code Playgroud)