簡體   English   中英

Django - 如何從具有外鍵的 model 中獲取所有項目?

[英]Django - How to get all items from a model that has foreign key?

我正在創建兩個模型:Feedstockformula 和 formula。 這是每個代碼:

原料配方:

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)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM