当项目可以出现在多个类别中时,返回出现在单个类别中的项目的Django查询集

时间:2015-11-24 18:28:49

标签: python django django-models django-orm

我正在尝试返回类别中所有项目的查询集,其中项目可以出现在多个类别中。下面是相关的模型声明以及许多不起作用的尝试之一。有没有办法使用Django的内置中间表功能,而无需为中间表显式声明模型?

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

    def items(self):
        curr_category = Category.objects.filter(pk=self.id)
        items_in_category = curr_category.item__categories_set.all().values('item_id')
        return Item.objects.filter(pk__in=items_in_category)

    def __unicode__(self):
        return self.name


class Item(models.Model):
    name = models.TextField(null=True,blank=True)
    price = models.DecimalField(max_digits=10, decimal_places=2,null=True,blank=True)
    categories = models.ManyToManyField(Category,null=True)

1 个答案:

答案 0 :(得分:1)

您可以通过models.Manager型号上的自定义Item来实现此目的。这是理想的,恕我直言,因为这个逻辑并不真正属于你的Category模型。如果你想要除Item以外的东西的类别怎么办?然后你必须在Category上实现更多的检索方法,膨胀它。

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

    def __unicode__(self):
        return self.name

class ItemManager(models.Manager):
    def get_for_category(self, category):
        return self.filter(categories=category)

class Item(models.Model):
    name = models.TextField(null=True,blank=True)
    price = models.DecimalField(max_digits=10, decimal_places=2,null=True,blank=True)
    categories = models.ManyToManyField(Category,null=True)
    objects = ItemManager()

然后使用:

调用它
items = Item.objects.get_for_category(category_instance)

如果你真的想用Category方法做,那么为什么不呢:

class Category(models.Model):

    def items(self):
        # probably need to import Item model here in order to avoid
        # circular import reference
        from myapp.models import Item
        return Item.objects.filter(categories__id=self.id)