我正在使用 Django 版本 2.2.11 和 MongoDB 作为数据库
我是一个简单的数组字段,用于在 Django REST 框架模型中存储字符串列表。我希望序列化的 JSON 输出是这样的。
{
name : "John"
roles : [ "string1", "string2" ]
}
我搜索了互联网,只能找到 PostgreSQL 的实现。
我只需要将角色的数据作为字符串/列表存储在数据库中,并且需要在 api 视图中以正确的格式显示。
编辑
我正在附加使用的模型和序列化程序。
class UserProfile(AbstractBaseUser, PermissionsMixin):
username = None
email = models.EmailField(max_length=255, unique=True)
name = models.CharField(max_length=255, default="")
is_active = models.BooleanField(default=True)
is_staff = models.BooleanField(default=False)
objects = UserProfileManager()
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = ['name',]
def get_full_name(self):
return self.name
def get_short_name(self):
return self.name
def __str__(self):
return (self.name + " - " + self.email)
class UserDetails(models.Model):
user_profile = models.OneToOneField(UserProfile, on_delete=models.CASCADE, related_name = 'user_details', null = False)
nickname = models.CharField(max_length=255, blank = True)
about = models.TextField(max_length=50000, blank=True)
# role =
def __str__(self):
return (self.user_profile.name +" - "+self.user_profile.email)
序列化器:
class UserDetailsSerializer(serializers.ModelSerializer):
user_profile = UserProfileSerializer(read_only=True)
class Meta:
model = UserDetails
fields = '__all__'
def create(self, validated_data):
user_profile = self.context['request'].user
validated_data['user_profile'] = user_profile
return super().create(validated_data)
UserDetails 模型中的角色字段应包含类似
role : ["President", "Admin"]
一个 JSON 字符串数组。