微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

通过外键链查找行

如何解决通过外键链查找行

假设我有以下表格:

带有 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'
                                         )
                     );

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

,

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。