Как djanog orm фильтровать обратный внешний ключ

Когда я использую django, я создал две модели.

class GroupModel(models.Model):
    group_name = models.CharField(max_length=2, null=False, default="A")


class MemberModel(models.Model):
    name = models.CharField(max_length=8, null=False, default="")
    group = models.ForeignKey(
        to=GroupModel,
        on_delete=models.CASCADE,
        related_name="members",
        db_column="member",
    )
    isActive = models.BooleanField(null=False, default=False)

Содержимое lisk:

[{'group_name': 'GROUP_A',
  'id': 1,
  'members': [{'isActive': False, 'name': 'j'},
              {'isActive': True, 'name': 'b'},
              {'isActive': True, 'name': 'y'}]},
 {'group_name': 'GROUP_B',
  'id': 2,
  'members': [{'isActive': True, 'name': 'f'},
              {'isActive': True, 'name': 'i'},
              {'isActive': True, 'name': 'y'}]}]

Теперь, я хочу получить набор запросов с isActive=False

queryset = GroupModel.objects.filter(members__isActive=True).distinct()

но результат будет

[{'group_name': 'GROUP_A',
  'id': 1,
  'members': [{'isActive': False, 'name': 'j'},
              {'isActive': True, 'name': 'b'},
              {'isActive': True, 'name': 'y'}]}]

Как я могу получить список ожидаемых результатов

[{'group_name': 'GROUP_A',
  'id': 1,
  'members': [{'isActive': False, 'name': 'j'}]}]

Вы можете попробовать следующее

GroupModel.objects.filter(members__isActive=False).distinct()

Я думаю, вам следует использовать MemberModel вместо класса GroupModel в вашем наборе запросов

queryset = MemberModel.objects.filter(isActive=False).distinct()
for objects in queryset:
    print(objects.name)

Спасибо

Вы можете фильтровать отношение также с помощью Prefetch объекта [Django-doc]:

from django.db.models import Prefetch

queryset = GroupModel.objects.filter(
    members__isActive=False
).prefetch_related(
    Prefetch('members', MemberModel.objects.filter(isActive=False))
).distinct()
Вернуться на верх