Django-如何从具有外键的模型中获取所有项目?

问题描述

我正在创建两个模型: 原料配方和配方。这是每个代码

原料配方:

from django.db import models

class FeedstockFormulas(models.Model):
    ratio = models.FloatField()
    Feedstock = models.OnetoOneField("dashboard.Feedstock",on_delete=models.CASCADE,default="0")
    formulas = models.ForeignKey("dashboard.Formulas",default="")

公式:

from django.db import models

class Formulas(models.Model):
    name = models.CharField(max_length=100)
    cost = models.FloatField()
    weight = models.FloatField()

如何获取公式中的所有FeedFormulas?

解决方法

您应在FeedstockFormulas的公式字段中添加“ related_name”。

赞:

formulas = models.ForeignKey("dashboard.Formulas",related_name="feed_stock_formulas",on_delete=models.CASCADE,default="")

Django在ForeignKey上使用反向关系,您可以通过编写以下代码来访问属于公式的所有FeedstockFormulas:

Formulas.feed_stock_formulas
,

您可以通过FeedstockFormulas字段的 related_name 访问formulas,在您的情况下默认为feedstockformulas_set

例如:

formula = Formulas.objects.first()
print(formula.feedstockformulas_set.all().feedstock)
,

您可以这样做

首先使用类似的内容获得所需公式的引用

f = Formula.objects.get(name = <formula name>)

然后使用它来获取原料配方

fsf = FeedstockFormulas.objects.filter(formulas = f)