gpt4 book ai didi

django - 如何在 django 中基于父查询集创建预取查询集

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

这是一个场景,一个包含多个投标的项目模型。

Class Project(models.Model):
user = models.ForeignKey()

Class Bid(models.Model):
project = models.ForeignKey(Project, related_name='bids')

当我们在查询项目时,我们想预取项目的投标。
Project.objects.filter(whatever condition).prefetch_related(
Prefetch('bids', queryset=Bid.objects.all())
)

这里我们只想获取属于过滤项目的投标,而不是所有的投标,我们如何指定?我期待类似的东西
queryset=Bid.objects.filter(project=project?)... 

谢谢。

最佳答案

Project.objects.filter(whatever condition).prefetch_related(
Prefetch('bids', queryset=Bid.objects.all())
)

这看起来没问题。 Django 只会为您获取相关的出价。请注意,您不需要 Prefetch在这种情况下。你可以这样做:
Project.objects.filter(whatever condition).prefetch_related('bids')
Prefetch如果要过滤查询集,则很有用,例如:
Project.objects.filter(whatever condition).prefetch_related(
Prefetch('winning_bids', queryset=Bid.objects.filter(status='WINNING'))
)

关于django - 如何在 django 中基于父查询集创建预取查询集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49003454/

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