早上好
我真的很难解决从Django Rest Framework API返回值的问题。
我有两个模型,SirTarget和Status。 SirTarget就像票证,“状态”是票证的文本状态标签,对应于处理票证的阶段。
模型如下:
class Status(models.Model):
status_text = models.CharField(max_length=20)
status_open = models.BooleanField(default=1)
def __str__(self):
return self.status_text
class SirTarget(models.Model):
name = models.CharField(max_length=70)
entry_date = models.DateTimeField(auto_now_add=True)
last_name = models.CharField(max_length=40)
first_name = models.CharField(max_length=40)
sir_status = models.ForeignKey(Status, on_delete=models.CASCADE, default=1, related_name='targets')
def __str__(self):
return '%d - %s %s' % (self.id, self.first_name, self.last_name)
我的序列化器如下:
class SirTargetStatusSerializer(serializers.ModelSerializer):
status_text = serializers.ReadOnlyField(source='Status.status_text')
class Meta:
model = SirTarget
fields = '__all__'
字段status_text不会作为API调用的一部分返回。返回数据时,我收到状态表的PK(1、2、3等),但没有收到status_text字段。
一段时间以来,我一直在苦苦挣扎。我已经引用了类似的设置,例如这篇文章: Retrieving a Foreign Key value with django-rest-framework serializers
但是,似乎没有什么对我有用。
EDIT
我也尝试过:
status_text = serializers.RelatedField(source='sir_status.status_text', read_only=True)
和
status_text = serializers.CharField(source='sir_status.status_text', read_only=True)
当我直接在数据库中查看时,我看到了要查找的内容并验证了这些值是否按预期填充:
# select * from sir_admin_status;
id | status_text | status_open
----+----------------+-------------
1 | New | t
2 | Open | t
3 | Referred | f
4 | Resolved | f
5 | False Positive | f
DRF 3.9.0 Python 3.7.1
谢谢您的帮助。
BCBB
答案 0 :(得分:2)
你应该做
class SirTargetStatusSerializer(serializers.ModelSerializer):
status_text = serializers.CharField(source='sir_status.status_text', read_only=True)
class Meta:
model = SirTarget
fields = ('name', ... , 'status_text') # explicitly define all field you want here
答案 1 :(得分:1)
要访问外键表中的所有字段,请使用“深度”
SirTargetStatusSerializer类(serializers.ModelSerializer):
MjYzZTVkZjdhOTNlYzVmNWVhNmFjMjE1ZWQ5NTdjMzA=