Django - 如何从具有外键的模型中获取所有项目?
Django - How to get all items from a model that has foreign key?
我正在创建两个模型:
原料配方和配方。这是每一个的代码:
原料配方:
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", on_delete=models.CASCADE, default="")
公式:
from django.db import models
class Formulas(models.Model):
name = models.CharField(max_length=100)
cost = models.FloatField()
weight = models.FloatField()
我怎样才能获得作为配方一部分的所有原料配方?
您应该将“related_name”添加到 FeedstockFormulas 中的公式字段。
像这样:
formulas = models.ForeignKey("dashboard.Formulas", related_name="feed_stock_formulas",on_delete=models.CASCADE, default="")
Django 在 ForeignKey 上使用反向关系,您可以通过编写以下内容访问作为公式一部分的所有 FeedstockFormulas:
Formulas.feed_stock_formulas
您可以通过 formulas
字段的 related_name
访问 FeedstockFormulas
,默认为 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)
我正在创建两个模型: 原料配方和配方。这是每一个的代码:
原料配方:
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", on_delete=models.CASCADE, default="")
公式:
from django.db import models
class Formulas(models.Model):
name = models.CharField(max_length=100)
cost = models.FloatField()
weight = models.FloatField()
我怎样才能获得作为配方一部分的所有原料配方?
您应该将“related_name”添加到 FeedstockFormulas 中的公式字段。
像这样:
formulas = models.ForeignKey("dashboard.Formulas", related_name="feed_stock_formulas",on_delete=models.CASCADE, default="")
Django 在 ForeignKey 上使用反向关系,您可以通过编写以下内容访问作为公式一部分的所有 FeedstockFormulas:
Formulas.feed_stock_formulas
您可以通过 formulas
字段的 related_name
访问 FeedstockFormulas
,默认为 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)