Django: Выбор количества полей внешнего ключа

У меня есть следующие модели:

class SystemTable(models.Model):
    id = models.FloatField(primary_key=True)
    system_name = models.CharField(max_length=50)
    system_desc = models.CharField(max_length=200, blank=True, null=True)
    system_url = models.CharField(max_length=2000, blank=True, null=True)
    status = models.ForeignKey(StatusLkp, models.DO_NOTHING, db_column='status',default=1)
    date_created = models.DateTimeField(default=datetime.now())
    objects = models.Manager()

    class Meta:
        app_label = 'system_table'
        managed = True
        db_table = 'system_table'


class SystemPagesTable(models.Model):
    id = models.FloatField(primary_key=True)
    system = models.ForeignKey(SystemTable, on_delete=models.CASCADE)
    page_name = models.CharField(max_length=200)
    page_link_xpath = models.CharField(max_length=2000)
    flag = models.FloatField(blank=True, null=True)
    status = models.ForeignKey(StatusLkp, models.DO_NOTHING, db_column='status',default=1)
    date_created = models.DateTimeField(default=datetime.now())
    objects = models.Manager()

    class Meta:
        app_label = 'system_pages_table'
        managed = True
        db_table = 'system_pages_table'

Я хочу выполнить следующий SQL-запрос:

select
  s.*,
  (select count(*) from page p where p.system_id = s.id) as NUM_OF_PAGES
from system s;

Как мне выполнить вышеприведенный запрос с помощью ORM Django без необходимости использовать for цикл ?
Мне не нужен результат, основанный на одной системе, я хочу получить все системы с их количеством страниц.

Попробуйте использовать annotate:

from django.db.models import Count
System.objects.annotate(num_pages=Count('page'))
Вернуться на верх