Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can the foreign field shows the name instead of its id?

In my models.py, there are two model, the AvailableArea has a foreign field refer to AddressRegion:

class AddressRegion(models.Model):
    name = models.CharField(max_length=8)

    def __str__(self):
        return self.name
    def __unicode__(self):
        return self.name


class AvailableArea(models.Model):
    name = models.CharField(max_length=8)
    addressregion = models.ForeignKey(AddressRegion, default=1, related_name='availableareas', on_delete=models.CASCADE)

    def __str__(self):
        return self.name
    def __unicode__(self):
        return self.name

In the serializers.py, I serialize all the fields:

class AvailableAreaSerializer(ModelSerializer):
    """
    可用地区
    """
    class Meta:
        model = AvailableArea
        fields = "__all__"

In the views.py:

class AddressRegionListAPIView(ListAPIView):
    serializer_class = AddressRegionSerializer
    permission_classes = []
    queryset = AddressRegion.objects.all()

The rest framework data is like this:

[
    {
        "id": 13,
        "name": "福州一区",
        "addressregion": 3
    },
    {
        "id": 14,
        "name": "西南一区",
        "addressregion": 4
    },
    {
        "id": 15,
        "name": "西南一区",
        "addressregion": 3
    }
]

I want the addressregion not shows the addressregion's id, but shows the addressregion's name.

like image 449
qg_java_17137 Avatar asked Nov 13 '17 13:11

qg_java_17137


3 Answers

You can do

class AvailableAreaSerializer(ModelSerializer):

    addressregion_name= serializers.ReadOnlyField(source='addressregion.name')

    class Meta:
        model = AvailableArea
        fields = ('id', 'name', 'addressregion_name')
like image 121
Daniel Avatar answered Oct 21 '22 06:10

Daniel


just add the following code in your serializer:

addressregion_name = serializers.StringRelatedField()

#should be like the following

class AvailableAreaSerializer(ModelSerializer):

addressregion_name = serializers.StringRelatedField()

class Meta:
    model = AvailableArea
    fields = ('id', 'name', 'addressregion__name')
like image 42
nsola Avatar answered Oct 21 '22 07:10

nsola


Your serializer should be like this:

class AvailableAreaSerializer(ModelSerializer):
"""
可用地区
"""
class Meta:
    model = AvailableArea
    fields = ('id', 'name', 'addressregion__name')

and queryset in View should be:

queryset = AddressRegion.objects.all().select_related('addressregion')

select_related will fetch the result by joining both the table. For more info read this

like image 44
Mohammad Mustaqeem Avatar answered Oct 21 '22 07:10

Mohammad Mustaqeem