SQL查询是:
select B.* from A inner join B on A.b_id = B.id where A.x in (1,2,3)
A <-> B 关系是多对一的
我需要按 A 过滤但获取相关的 B。
更新:
我试过这个 NH QueryOver
Session.QueryOver<A>.Where(a => a.x.IsIn(array)).JoinQueryOver(a => a.B).Select(a => a.B).List<B>()
但它会导致 N+1 的查询序列:第一个获取相关 B 的 ID,而其他查询则通过 ID 一个接一个地获取相关 B(通过 NHProf 分析)。我希望它一次性获取 B 列表。
更新 2:
现在我用子查询解决了这个问题
Session.QueryOver(() => b).WithSubquery.WhereExists(QueryOver.Of<A>().Where(a => a.x.IsIn(array)).And(a => a.b_id == b.id).Select(a => a.id)).List<B>()
但我仍然希望看到一个没有子查询的 QueryOver 示例,因为我倾向于认为子查询效率较低。