- ru
- Language: en
- Documentation version: 2.0
5. How to order on an annotated field?
You have two models, Category
and Hero
.
class Category(models.Model):
name = models.CharField(max_length=100)
class Hero(models.Model):
# ...
name = models.CharField(max_length=100)
category = models.ForeignKey(Category, on_delete=models.CASCADE)
You want to get the Category
, ordered by number of Hero
in them. You can do this.
Category.objects.annotate(
hero_count=Count("hero")
).order_by(
"-hero_count"
)