gpt4 book ai didi

c# - 使用 nhibernate 时,如何执行 ThenFetch() 然后引入多个属性/连接?

转载 作者:行者123 更新时间:2023-11-30 13:06:15 32 4
gpt4 key购买 nike

我有以下代码作为 Fluent NHibernate 查询的一部分

session.Query<Project>()
.Where(r=>r.IsActive)
.FetchMany(r => r.ProjectDependencies)
.ThenFetch(r => r.DependencyProject)
.ThenFetch(r => r.Owner)

上面的代码工作正常,但问题是我现在想加入并加载一些额外的“属性”,这些属性是从 DependencyProject 对象中加入的,除了 Owner(如上所述)。所以我想做这样的事情:

session.Query<Project>()
.Where(r=>r.IsActive)
.FetchMany(r => r.ProjectDependencies)
.ThenFetch(r => r.DependencyProject)
.ThenFetch(r => r.Owner)
.AndAlsoFetch(r=>r.Status)

或者像这样:

session.Query<Project>()
.Where(r=>r.IsActive)
.FetchMany(r => r.ProjectDependencies)
.ThenFetch(r => r.DependencyProject)
.ThenFetch(r => r.Owner && r.Status)

无论如何,是否可以从一个已经作为 ThenFetch 的一部分引入的对象中多次提取属性?

最佳答案

我目前无法测试,所以这可能偏离了基础,但这可能是一种可能的方法:

  var query = session.Query<Project>()
.Where(r=>r.IsActive)
.FetchMany(r => r.ProjectDependencies)
.ThenFetch(r => r.DependencyProject);

query.ThenFetch(r => r.Owner).ToFuture();
query.ThenFetch(r => r.Status).ToFuture();

Project project = query.ToFuture().ToList();

关于c# - 使用 nhibernate 时,如何执行 ThenFetch() 然后引入多个属性/连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32413338/

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