如何在Django视图中通过外键访问其他模型字段

时间:2020-08-09 02:19:43

标签: python django

我想从OrderItem模型查询 total_orders = OrderItem.objects.filter(product.user == request.user.id).count() 但是我出错了

** / home中的NameError 名称“产品”未定义 **

我的模型:

产品型号:

class Product(models.Model):
    title = models.CharField(max_length=150)
    user = models.ForeignKey(
        User, blank=True, null=True, on_delete=models.SET_DEFAULT, default=None)
    description = models.TextField()
    price = models.FloatField()
    quantity = models.IntegerField(default=False, null=True, blank=False)
    minorder = models.CharField(
        max_length=150, help_text='Minum Products that want to sell on per order', null=True, default=None, blank=True)
    image = models.ImageField()

    category = models.ForeignKey(
        Categories, default=1, on_delete=models.CASCADE)
    slug = models.SlugField(blank=True, unique=True)

    def __str__(self):
        return self.title

订单项模型

class OrderItem(models.Model):
    product = models.ForeignKey(
        Product, on_delete=models.SET_NULL, blank=True, null=True)
    order = models.ForeignKey(
        Order, on_delete=models.SET_NULL, blank=True, null=True)
    quantity = models.FloatField(default=0, null=True, blank=True)
    date_orderd = models.DateTimeField(auto_now_add=True)
    user = models.ForeignKey(
        User, on_delete=models.SET_NULL, blank=True, null=True)
    price = models.FloatField(blank=True, null=True)

    def __str__(self):
        return str(self.product)

我的观点:

def home(request):
total_orders = OrderItem.objects.filter(
        product.user == request.user.id).count()
    return render(request, "sellerprofile/home.html", {'total_orders': total_orders})

1 个答案:

答案 0 :(得分:1)

要做:

Unable to evaluate the expression.

您可以详细了解有关字段查找的文档here