Opgelost: hoe gegevens naar externe sleutel te posten in django rest framework

Het grootste probleem is dat u de POST-methode moet gebruiken om gegevens naar de externe sleutel te verzenden.

I have a model with a foreign key. I am trying to post data to this model using the Django Rest Framework. How do I post data to the foreign key?
<code>class Model1(models.Model):
    name = models.CharField(max_length=100)

    def __str__(self):
        return self.name


class Model2(models.Model):
    name = models.CharField(max_length=100)
    model1 = models.ForeignKey('Model1', on_delete=models.CASCADE, related_name='model2')

    def __str__(self):
        return self.name


class Model2Serializer(serializers.ModelSerializer):

    class Meta:  # noqa: D106,D205,D400,E501  # pylint: disable=too-few-public-methods,missing-docstring,line-too-long,no-init  # noqa: D105  # pylint: disable=R0903  # noqa: D102  # pylint: disable=R0901  

        model = Model2  
        fields = ['id', 'name', 'model1']  
</code>

Deze code definieert twee modellen, Model1 en Model2, en een serializer voor Model2.
Model1 heeft een veld genaamd name.
Model2 heeft een veld genaamd name, en een extern sleutelveld genaamd model1. De externe sleutel linkt naar de Model1.
De serializer voor Model2Serializer, definieert welke velden moeten worden opgenomen bij het converteren van het model naar JSON-indeling. In dit geval bevat het de velden: id, name, and 'model1'.

Save Foreign Key Using Django Rest Framework

In Django, you can use the save_foreign_key() function to save a foreign key in a model. This function takes two arguments: the model name and the name of the column in the model that stores the foreign key.

To save a foreign key in a model named "MyModel", you would use the following code:

save_foreign_key("MyModel", "id")

What is Foreign key

A foreign key is a column in a table that references a column in another table. When you insert data into the table, Django automatically creates the foreign key for you.

Related posts:

Leave a Comment