Ранжирование модели A по модели B - PullRequest
0 голосов
/ 29 марта 2019

У меня есть модель игры и модель подписки:

class Game(models.Model):
    title = models.CharField(max_length=100)
    slug = models.SlugField(unique=True)
    cover = models.ImageField(upload_to='cover_images')

    def __str__(self):
        return self.title

    class Meta:
        ordering = ['title']

class Subscription(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    game = models.ForeignKey(Game, on_delete=models.CASCADE)
    created_at = models.DateTimeField(auto_now_add=True)
    updated_at = models.DateTimeField(auto_now=True)
    is_active = models.BooleanField(default=True)

    def __str__(self):
        return str(self.id)

Теперь я пытаюсь выяснить, как отсортировать Игры по количеству подписчиков.

1 Ответ

3 голосов
/ 29 марта 2019

Вы можете сделать это в Django> = 2.0:

class Game(models.Model):
    # Previous code

    class Meta:
        ordering = [Count('subscription').desc(nulls_last=True)]

В старых версиях вы можете сделать это:

Game.objects.all().annotate(num_subscribers=Count('subscription')
                  .order_by('-num_subscribers')
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...