玩具
、玩具 -> ChildToys
、玩具 -> ChildToys -> 汽车
我有与 Toys -> ChildToys 相关的产品-> 汽车
,我可以通过汽车
获取所有产品,但是如何通过过滤玩具
类别获取产品。到目前为止我做了什么
class Category(models.Model):
name = models.CharField(max_length=100)
slug = models.SlugField(max_length=100, blank=True, unique=True)
icon = models.ImageField(upload_to='category_icons', null=True, blank=True)
parent = models.ForeignKey('self', on_delete=models.SET_NULL, related_name='children', null=True, blank=True)
class Product(models.Model):
category = models.ForeignKey(Category, blank=True, null=True, on_delete=models.CASCADE)
name = models.CharField(max_length=200)
class ProductList(generics.ListAPIView):
serializer_class = ProductSerializer
def get_queryset(self):
slug = self.request.query_params.get('slug', None)
parent_id = Category.objects.get(slug=slug)
cats = Category.objects.filter(parent_id=parent_id)
qs = Product.objects.filter(category_id__in=parent_id)
print(qs)
return qs
最佳答案
如果您需要遍历整个子树,则需要在 Category
模型上创建一个方法,以递归方式获取所有子类别。有another post这向您展示了如何做到这一点。
假设您有该方法Category.get_family_tree()
class Category(models.Model):
# fields
def get_family_tree(self):
# code from question linked above
# returns list of `Category` instances
然后在您看来,您可以像这样获取产品:
def get_queryset(self):
slug = self.request.query_params.get('slug')
categories = Category.objects.get(slug=slug).get_family_tree()
return Product.objects.filter(category__parent__in=categories)
关于python - 从父类别 django rest 获取所有产品,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59267201/