繁体   English   中英

Django rest框架用FK序列化model

[英]Django rest framework serialize model with FK

我正在学习 Django 和 Vue.js。 有些东西我不明白它是如何工作的。

我有一个 model “Nc”,它对其他模型(如 Affaire)有一些外键。

如何在我的 JSON 文件中获取str返回实例而不是实际值...

模型.py:

class Affaires(models.Model):
    id = models.PositiveSmallIntegerField(primary_key=True)
    nom = models.CharField(max_length=50)
    adresse = models.CharField(max_length=100, blank=True, null=True)
    cp = models.CharField(max_length=5, blank=True, null=True)
    ville = models.CharField(max_length=50, blank=True, null=True)
    dessinateur = models.PositiveSmallIntegerField(blank=True, null=True)
    conducteur = models.PositiveSmallIntegerField(blank=True, null=True)
    chefdeprojet = models.PositiveSmallIntegerField(blank=True, null=True)
    cloture = models.IntegerField()


    class Meta:
        managed = True
        db_table = 'affaires'

    def __str__(self):
        return '{} - {}'.format(self.id, self.nom)

class NC(models.Model):
    idaffaire = models.ForeignKey(Affaires, models.DO_NOTHING,verbose_name="N° d'affaire", db_column='idAffaire')
    idof = models.ForeignKey(AffairesOfs, models.DO_NOTHING,verbose_name="N° d'OF", db_column='idOf')
    idposte = models.ForeignKey(ProductionPostes, models.DO_NOTHING,verbose_name="Poste", db_column="idPoste")
    idrepere = models.ForeignKey(AffairesReperes, models.DO_NOTHING,verbose_name="Repère", db_column='idRepere')
    idnc = models.ForeignKey(Nc_type, models.DO_NOTHING,verbose_name="Type de NC", db_column='idNc_type')
    quantite = models.PositiveIntegerField(verbose_name="Quantité")
    dateajout = models.DateField(default=timezone.now, verbose_name="Date d'ajout", db_column='dateAjout')

    class Meta:
        managed = True
        db_table = 'qualite_Nc'

序列化.py

class NcSerializer(serializers.ModelSerializer):

    class  Meta:
        model = NC
        fields = '__all__'

JSON 文件:

{
        "id": 1,
        "quantite": 1,
        "dateajout": "2020-04-08",
        "idaffaire": 1145,
        "idof": 1433,
        "idposte": 6271,
        "idrepere": 5361,
        "idnc": 1
    },
    {
        "id": 2,
        "quantite": 17,
        "dateajout": "2020-04-09",
        "idaffaire": 1205,
        "idof": 1290,
        "idposte": 5812,
        "idrepere": 7004,
        "idnc": 1
    },

我在 JSON 上想要的结果:

{
        "id": 1,
        "quantite": 1,
        "dateajout": "2020-04-08",
        "idaffaire": 1145 - CORTIS,
        "idof": 1433,
        "idposte": 6271,
        "idrepere": 5361,
        "idnc": 1
    },
    {
        "id": 2,
        "quantite": 17,
        "dateajout": "2020-04-09",
        "idaffaire": 1205 - GS Cergy,
        "idof": 1290,
        "idposte": 5812,
        "idrepere": 7004,
        "idnc": 1
    },

我不确定问题是在 JSON 文件上返回str 事实上,我不明白我应该如何将 Serialize 与 FK 一起使用。

使用serializers.StringRelatedField()字段作为,

class NcSerializer(serializers.ModelSerializer):
    idaffaire = serializers.StringRelatedField()

    class Meta:
        model = NC
        fields = '__all__'

您必须为每个外来对象创建一个序列化程序。

我会亲自从idaffaire中删除所有前缀id NC ,因为您可以执行诸如instance.affaire.idinstance.idaffaire.id之类的操作没有多大意义。

代码示例:

class AffairesSerializer(serializers.ModelSerializer):

    class  Meta:
        model = Affaires
        fields = '__all__'

class NcSerializer(serializers.ModelSerializer):
    affaire = AffairesSerializer(read_only=True)

    class  Meta:
        model = NC
        fields = '__all__'

确保在创建查询集时使用select_related('affaire')以避免对数据库的不必要请求。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM