为了账号安全,请及时绑定邮箱和手机立即绑定

根据特定类别名称过滤对象

根据特定类别名称过滤对象

Go
狐的传说 2022-06-07 16:32:14
我正在尝试过滤类别名称为“书籍”的所有产品。请参阅下面我尝试过的内容,但我得到一个空的查询集。这是我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个赞

使用数据库工具检查数据库后,我意识到CategoryForeignKey 是NULL. 问题是我在保存父母之前分配了父母,这意味着他们没有 PrimaryKey,所以 ForeignKey 设置为NULL.



查看完整回答
反对 回复 2022-06-07
  • 1 回答
  • 0 关注
  • 166 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号