Проверьте уникальность, пропустите и введите данные соответственно в Django API - PullRequest
0 голосов
/ 28 марта 2019

Я хочу создать условие, при котором я беру данные из API Google Place. В моей модели place_id это unique поле. Я создал API, где он принимает несколько данных - примерно так - [{},{},{}].

Когда я ввожу данные с двумя одинаковыми place_id, это дает ошибку - "masjid with this place id already exists.".

Вместо этой уникальной ошибки place_id. Я хочу проверить, если place_id уже существует, не выдавайте ошибку, просто пропустите ее и введите те данные, которые имеют уникальный place_id.

Здесь я приведу пример, где я отправляю данные, используя json.

[
    {
        "name": "Jama masjid",
        "address": "XYZ",
        "latitude": 25454.25,
        "longitude": 1541.4,
        "place_id": "place_id" <---- This place_id already exist in database
    },
    {
        "name": "Noor masjid",
        "address": "kondhwa",
        "latitude": 25454.25,
        "longitude": 1541.4,
        "place_id": "place_id1"
    }
]

Так что в Response он выдает эту ошибку -

[
    {
        "place_id": [
            "masjid with this place id already exists."
        ]
    },
    {}
]

Примечание. - Я отправляю несколько данных - many=True

Models.py

class Masjid(models.Model):
    name = models.CharField(max_length=255, null=True, blank=True)
    address = models.CharField(max_length=255, null=True, blank=True)
    place_id = models.CharField(max_length=255, null=True, blank=True, unique=True)
    latitude = models.FloatField(blank=True, null=True)
    longitude = models.FloatField(blank=True, null=True)

Views.py

class MasjidAddGoogleAPIView(generics.CreateAPIView):
    queryset = Masjid.objects.all()
    serializer_class = serializers.MasjidAddGoogleSerialzer
    permission_classes = [IsAuthenticated]

    def list(self, request):
        queryset = self.get_queryset()
        serializer = serializers.MasjidAddGoogleSerialzer(queryset, many=True)
        return Response(serializer.data)

    def post(self, request, format=None):
        data = request.data
        print(data)
        if isinstance(data, list):
            serializer = self.get_serializer(data=request.data, many=True)
        else:
            serializer = self.get_serializer(data=request.data)
        if serializer.is_valid():
            serializer.save()
            return Response(serializer.data, status=status.HTTP_201_CREATED)
        return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)

serilizers.py

class MasjidAddGoogleSerialzer(serializers.ModelSerializer):
    class Meta:
        model = Masjid
        fields = [
            'name',
            'address',
            'latitude',
            'longitude',
            'place_id'
        ]  

1 Ответ

0 голосов
/ 28 марта 2019

Я нашел решение.Я перебрал список, который был отправлен.Затем я сопоставил поле place_id с базой данных и создал новый list.Согласно этим новым list данным, введенным в базу данных.

Создание нового списка -

data_final = [i for i in data if not (Masjid.objects.filter(place_id=i['place_id']).exists() == True)] 

Views.py

class MasjidAddGoogleAPIView(generics.CreateAPIView):
    queryset = Masjid.objects.all()
    serializer_class = serializers.MasjidAddGoogleSerialzer
    permission_classes = [IsAuthenticated]

    def list(self, request):
        queryset = self.get_queryset()
        serializer = serializers.MasjidAddGoogleSerialzer(queryset, many=True)
        return Response(serializer.data)

    def post(self, request, format=None):
        data = request.data

        if data:   

            if isinstance(data, list):   

                data_final = [i for i in data if not (Masjid.objects.filter(place_id=i['place_id']).exists() == True)]        

                if data_final:
                    serializer = self.get_serializer(data=data_final, many=True)

                    if serializer.is_valid():
                        serializer.save()
                        return Response(serializer.data, status=status.HTTP_201_CREATED)

            else:
                serializer = self.get_serializer(data=request.data)

                if serializer.is_valid():
                        serializer.save()
                        return Response(serializer.data, status=status.HTTP_201_CREATED)

        return Response(status=status.HTTP_204_NO_CONTENT)
...