我正在使用Django Rest Framework构建API。数据库引擎是PostgreSQL。
当我导航到Persons API时,我可以输入身份编号,姓氏并从预定义列表中选择名字,如下面的屏幕截图所示:
这不是我打算创建的功能
如何更改我的代码,以便我可以为一个人输入任意数量的名字,然后我可以标记/选择其中一个名字作为主要名字?
这是我的models.py
class Person(models.Model):
created = models.DateTimeField(auto_now_add=True)
updated = models.DateTimeField(auto_now=True)
owner = models.ForeignKey('auth.User', related_name='persons')
identity_number = models.CharField(max_length=50)
primary_first_name = models.CharField(max_length=50)
last_name = models.CharField(max_length=50)
class Meta:
ordering = ('created',)
class FirstName(models.Model):
first_name = models.CharField(max_length=50)
person= models.ForeignKey(Person, related_name='first_names', on_delete=models.CASCADE)
class Meta:
ordering = ('person',)
def __unicode__(self):
return '%s' % (self.first_name)
这是我的serializers.py
class PersonSerializer(serializers.HyperlinkedModelSerializer):
owner = serializers.ReadOnlyField(source='owner.username')
first_names = serializers.StringRelatedField(many=True)
class Meta:
model = Person
fields = ('created', 'updated', 'url', 'owner',
'identity_number', 'last_name', 'first_names')
答案 0 :(得分:2)
为了让Django知道主要名字应该是第一个名字实例的“指针”,你应该稍微修改你的模型:
class Person(models.Model):
primary_first_name = models.ForeignKey('FirstName')
你问题的第二部分有点棘手。所以你希望Django Rest Framework生成一个“管理界面”来创建一些名字,然后允许你将某些名称作为主要名称?我猜你最好坚持使用内联的django.contrib.admin
。 DRF肯定没有这么复杂的界面,毕竟它只是对象(反)序列化。