gpt4 book ai didi

python - 我如何将这些多重连接作为 Django 查询集进行?

转载 作者:行者123 更新时间:2023-12-01 09:30:04 24 4
gpt4 key购买 nike

我有一个将多个表连接在一起的查询:

select 
p.player_id
, d.player_data_1
, l.year
, l.league
, s.stat_1
, l.stat_1_league_average
from
stats s
inner join players p on p.player_id = s.player_id
left join player_data d on d.other_player_id = p.other_player_id
left join league_averages as l on l.year = s.year and l.league = s.year
where
p.player_id = 123

我的模型如下所示:

class Stats(models.Model):
player_id = models.ForeignKey(Player)
stat_1 = models.IntegerField()
year = models.IntegerField()
league = models.IntegerField()


class Player(models.Model):
player_id = models.IntegerField(primary_key=True)
other_player_id = models.ForeignKey(PlayerData)

class PlayerData(models.Model):
other_player_id = models.IntegerField(primary_key=True)
player_data_1 = models.TextField()

class LeagueAverages(models.Model):
year = models.IntegerField()
league = models.IntegerField()
stat_1_league_average = models.DecimalField()

我可以做这样的事情:

Stats.objects.filter(player_id=123).select_related('player')

进行第一次加入。对于第二次加入,我尝试了:

Stats.objects.filter(player_id=123).select_related('player').select_related('player_data')

但是我收到了这个错误:

django.core.exceptions.FieldError: Invalid field name(s) given in select_related: 'player_data'. Choices are: player

考虑到 yearleague 不是任何表中的外键,我将如何进行第三次连接?谢谢!

最佳答案

select_related(*fields) Returns a QuerySet that will “follow” foreign-key relationships, [...]

根据 django 文档 select_lated 遵循外键关系。 player_data 更不是外键,甚至也不是 Stats 的字段。如果您想要内部连接 PlayerDataPlayer,您可以遵循其外键。在你的情况下使用 double-underscore获取PlayerData:

Stats.objects.all()
.select_related('player_id')
.select_related('player_id__other_player_id')

至于加入LeagueAverages:没有办法在没有适当外键的情况下加入模型,而是使用原始sql。看看相关问题:Django JOIN query without foreign key 。通过使用 .raw() ,您的 LEFT join (顺便说一下,如果不使用 raw: Django Custom Left Outer Join ,这也不是那么容易)。

有关模型的快速说明:

  1. 默认情况下,每个模型都有一个自动递增的主键,可以通过 .id.pk 访问该主键。因此不需要添加例如 player_id
  2. models.ForeignKey 字段引用一个对象而不是它的 ID。因此,将 player_id 重命名为 player 会更直观。如果您将字段命名为 player,django 允许您通过 player_id
  3. 自动访问它的 id

关于python - 我如何将这些多重连接作为 Django 查询集进行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50047815/

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