Фильтровать объекты по названию определенной категории - PullRequest
0 голосов
/ 25 сентября 2019

Я пытаюсь отфильтровать все товары, название категории которых - «Книги».Ниже показано, что я пробовал, но я получаю пустой набор запросов.

Вот мой models.py на всякий случай:

from django.db import models
from django.urls import reverse

[...]      

class Product(models.Model):
    title = models.CharField(max_length=200)
    description = models.TextField()
    price = models.DecimalField(decimal_places=2, max_digits=10)
    year = models.PositiveSmallIntegerField()
    image = models.ImageField(upload_to=get_image_path, blank=True, null=True)
    date_added = models.DateTimeField(auto_now=True, null=True)
    category = models.ForeignKey('Category', on_delete=models.CASCADE)

    [...]

class Category(models.Model):
    parent = models.ForeignKey('self', null=True, blank=True, on_delete=models.CASCADE)
    name = models.CharField(max_length=255)

    def __str__(self):
        return self.name

Я пробовал это:

>>> from products.models import Product, Category
>>> c = Category(name='Books')
>>> c1 = Category(name='Textbooks', parent=c)
>>> c2 = Category(name='Primary school', parent=c1)
>>> p = Product(title='spam', description='spameggs', price=200, year=2018, category=c2)
>>> for x in (c, c1, c2, p):
...     x.save()
... 
>>> Product.objects.get(category=c2)
<Product: Product object (1)>
>>> Product.objects.filter(category__name='Books')
<QuerySet []>
>>> Product.objects.filter(Q(category__name='Books') | Q(category__parent__name='Books') | Q(category__parent__parent__name="Books"))
<QuerySet []>

1 Ответ

0 голосов
/ 26 сентября 2019

После проверки базы данных с помощью инструмента базы данных я понял, что Category ForeignKey равен NULL.Проблема заключалась в том, что я назначал родителей до их сохранения, а это означало, что у них не было PrimaryKey, поэтому для ForeignKey было установлено значение NULL.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...