我正在嘗試過濾類別名稱為“書籍”的所有產品。請參閱下面我嘗試過的內容,但我得到一個空的查詢集。這是我models.py的以防萬一:from django.db import modelsfrom 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 回答

一只名叫tom的貓
TA貢獻1906條經驗 獲得超3個贊
使用數據庫工具檢查數據庫后,我意識到Category
ForeignKey 是NULL
. 問題是我在保存父母之前分配了父母,這意味著他們沒有 PrimaryKey,所以 ForeignKey 設置為NULL
.
- 1 回答
- 0 關注
- 157 瀏覽
添加回答
舉報
0/150
提交
取消