我想知道遵循 DDD 的人如何通过使用 EF 和存储库模式来解决潜在的性能问题,并返回带有子节点的聚合根。
例如父母 ----- 孩子 A
甚至例如 Parent ----- Child A ------- Child A2
- 如果我从存储库中取回聚合根的数据并使用导航属性 EF,则会触发另一个查询,因为它正在使用延迟加载。这是一个问题,因为当我们处于循环中时,我们会遇到 100 多个查询。
- 如果我通过使用“包含”语句从存储库中带回聚合根的数据以及子数据,这将从存储库中带回子数据及其父数据。然后,当我使用导航属性时,不会触发任何查询,因为该数据已经在内存中。
第二种方法的问题是我们的一些子对象数据可能非常大,例如 100,000+ 条记录。显然,我不想为孩子在内存中存储 100,000 多条记录。我们决定使用分页一次选择 10 个来解决这个问题,但另一个问题是,当我们尝试对子项使用总和、总数等计算时,我们只能在内存中对我们拥有的 10 条记录执行此操作拉回来。
我知道 DDD 方法是将对象图及其所有数据都放在内存中,然后遍历对象以获取需要显示的数据。
在我们的团队中存在分歧,一些人认为我们应该将聚合根及其子对象一起拉回,而有些人认为我们应该在聚合根的存储库上使用一种方法,直接查询子数据并拉回子对象。
我只是想知道其他人如何解决与父/子一起存储在内存中的大量数据的性能问题。