Как отфильтровать только вложенные связанные объекты django?

У меня есть модель, представляющая комнату и модуль. Модуль может иметь несколько комнат. Вот результат запроса get для моего объекта модуля -

{
            "module_id": 4,
            "rooms": [
                {
                    "room_id": 2,
                    "title": "4",
                    "desc": "22",
                    "level": "2",
                    "is_deleted": true,
                },
                {
                    "room_id": 3,
                    "title": "3",
                    "desc": "22",
                    "level": "2",
                    "is_deleted": false,
                }
            ],
            "title": "4",
            "desc": "sdsdsdss",
            "is_deleted": false,
        }

Теперь я хочу, чтобы запрос get модулей показывал все модули, а комнаты, содержащиеся в каждом модуле, должны иметь is_deleted=False. Другими словами, я не хочу, чтобы комната с room_id=2 была показана в get-запросе.

Вот мой файл views.py -

class add_module(APIView):
    def get(self, request, format=None):
        module = Module.objects.filter(is_deleted=False, rooms__is_deleted=False)
        module_serializer = ModuleSerializer(module, many=True)
        return Response(module_serializer.data, status = status.HTTP_200_OK)

Вот мой файл сериализатора для модуля -

class ModuleSerializer(serializers.ModelSerializer):
    rooms = RoomSerializer(read_only=True, many=True)
    class Meta:
        model = Module
        fields = "__all__"

Вам нужно указать конкретную предварительную выборку в queryset, например, так:

from django.db.models import Prefetch

module = Module.objects.filter(
    is_deleted=False
).prefetch_related(
    Prefetch(
        "rooms",
        queryset=Room.objects.filter(is_deleted=False)
    )
)
Вернуться на верх