Как мне отфильтровать всех потомков модели ForeignKey MPTT?
Здесь ситуация. Я использую модель MPTT в Django для создания иерархии музыкальных жанров (рок, хард-рок и т. Д.). Я назначаю один из узлов этой иерархии для альбома. Допустим, я создаю объект Album в жанре хард-рок. Как я могу запросить свои Альбомы для всех альбомов Рока и включить в него Рок и всех потомков жанра Рок?
class Genre(MPTTModel):
name = models.CharField(max_length=50, unique=True)
parent = TreeForeignKey('self', null=True, blank=True, related_name='children')
class MPTTMeta:
order_insertion_by = ['name']
def __unicode__(self):
return self.name
class Album(models.Model):
name= models.CharField(max_length=200)
genre= models.ForeignKey(Genre)
1 ответ
Использовать get_descendants()
метод MPTTModel
:
genres = album.genre.get_descendants(include_self=True)
albums = Album.objects.filter(genre__in=genres)