通过外键链查找行

问题描述

假设我有以下表格:

带有 ID 和名称的星星
具有 ID、名称和 StarId 的行星
带有 ID、名称和行星 ID 的月亮

StarIdPlanetId 都是外键。 在实体框架核心中,很容易找到属于特定恒星的所有卫星:

   var moons = await db.Moons.Where(m => m.Planet.Star.Name == "Sun").ToListAsync();

我的问题是是否有一种快速方法可以在事务 sql 中做同样的事情。可以通过连接来做到这一点。但我见过的每个例子都比人们想要的多得多。

解决方法

如果你想让月亮围绕我们的太阳,你可以使用:

select m.*
from Moon m join
     Planet p
     on p.Id = m.planetid join
     Star s
     on s.Id = p.starid
where s.name = 'Sun';

这可能不像你的语法那么简洁,但实际上很简单。

有些人不喜欢显式连接,所以他们可能会写:

select m.*
from moons m
where m.planet_id in (select p.planet_id
                      from planets p
                      where p.star_id in (select s.star_id
                                          from stars s
                                          where s.name = 'Sun'
                                         )
                     );

这种风格对我没有吸引力,它往往会产生更糟糕的执行计划。

,

根据一些评论,答案似乎是“不,没有。连接语法是必要的。”在另一个答案中对此进行了很好的描述。