Gelöst: wie man Daten an einen Fremdschlüssel im Django-Rest-Framework sendet

Das Hauptproblem besteht darin, dass Sie die POST-Methode verwenden müssen, um Daten an den Fremdschlüssel zu senden.

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>

Dieser Code definiert zwei Modelle, Model1 und Model2, und ein Serialisierer für Model2.
Model1 hat ein Feld namens name.
Model2 hat ein Feld namens name, und ein Fremdschlüsselfeld namens model1. Der Fremdschlüssel verlinkt auf die Model1.
Der Serialisierer für Model2Serializer, definiert, welche Felder beim Konvertieren des Modells in das JSON-Format enthalten sein sollen. In diesem Fall umfasst es die Felder: 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