如何使用 MongoDB 在 Django REST 框架模型中获取字符串列表

How to have list of strings in Django REST framework model using MongoDB

我正在使用 Django 版本 2.2.11,MongoDB 作为数据库

我是一个简单的数组字段,用于在 Django REST 框架模型中存储字符串列表。我希望序列化的 JSON 输出像这样。

{
   name : "John"
   roles : [ "string1", "string2" ]
}

我在网上搜索了一下,只能找到 PostgreSQL 的实现。

我只需要将角色数据作为 string/list 存储在数据库中,并需要在 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 字符串数组。

这是我使用的解决方法

djongo 库本身不支持模型字段列表。如果你使用的是MongoDB,有两个选项。

  1. 将输入保存为文本文件,并在 return 到 API 结束时将其序列化到列表中。
  2. 使用带有一个模型字段的抽象模型class。使用 djongo 库中的 ArrayField。这将数据作为对象存储在数据库中。您必须手动处理序列化程序方法。对于 get 请求,序列化程序可以使用 serializer.SerializerMethodField() 和 return 原始类型列表(如 Char)而不是对象列表。

我觉得第二个选项更好。