Как отфильтровать только вложенные связанные объекты 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)
)
)