django фильтр остаточного каркаса для связанных таблиц - PullRequest
1 голос
/ 28 февраля 2020

Мне нужна помощь в фильтрации полей в связанной таблице.

У меня есть две модели Kalas и имена, где одна (модель Kalas) имеет отношение один к одному с основанием c Модель пользователя:

class Kalas(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    visitKalas = models.ForeignKey('self', on_delete=models.DO_NOTHING, blank=True, null=True)
    isActive = models.BooleanField(default=True)
    capacity = models.IntegerField(default=0)
    fullName = models.CharField(max_length=100, default="default name")
    phoneNumber = models.IntegerField()
    address = models.CharField(max_length=40)
    postal = models.CharField(max_length=50)
    time = models.DateTimeField(auto_now_add=True)
    lat = models.FloatField(default=0)
    lng = models.FloatField(default=0)

    def __str__(self):
        return "user: %s, address: %s %s" % (self.user, self.address, self.postal)

class names(models.Model):
    kalasID = models.ForeignKey(Kalas, on_delete=models.CASCADE, related_name='names')
    name = models.CharField(max_length=30)

и я создал вложенный сериализатор:

class NamesMapSerializer(serializers.ModelSerializer):
class Meta:
    model = names
    fields = ['name']


class KalasMapSerializer(serializers.ModelSerializer): #bruk denne hver gang man vil ha kalas og navn sammen
    names = NamesMapSerializer(many=True, read_only=True)
    class Meta:
        model = Kalas
        fields = ['id', 'fullName', 'capacity', 'lat', 'lng', 'names']


class MapSerializer(serializers.ModelSerializer):
    kalas = KalasMapSerializer()
    class Meta:
        model = User
        fields = ['username', 'kalas']

и представление, в котором перечислены все пользователи и его кала с именами:

class MapViewSet(viewsets.ModelViewSet):
    queryset = User.objects.all()
    permissions_classes = [permissions.AllowAny]
    serializer_class = MapSerializer

, но я не знаю, как фильтровать, чтобы он показывал пользователям с kalas только то, что я активен kalas.isActive = True.

Я пробовал это, но теперь он проверяет пользовательские модели is_active, а не поле isActive Каласа:

class ActiveOnMap(generics.ListAPIView):
    def get_queryset(self):
        return User.objects.all().filter(isActive=True)
    serializer_class = MapSerializer

Пожалуйста, помогите мне новичку ie:)

1 Ответ

0 голосов
/ 28 февраля 2020

Обновите фильтр набора запросов, как показано ниже:

class ActiveOnMap(generics.ListAPIView):
    def get_queryset(self):
        return User.objects.filter(kalas__isActive=True)
    serializer_class = MapSerializer

Надеюсь, это поможет вам:)

...