首页 > 解决方案 > 显示并序列化 select_related() 模型方法的结果

问题描述

我有两个简单的模型:用户(标准 Django 用户)和类 Post(models.Model):

class Post (models.Model):
   name = models.CharField(max_length=100)
   user = models.ForeignKey(User, on_delete=models.CASCADE)
   def __str__(self):
    return self.name

我的前端 (SPA) 发送请求以获取所有帖子,因此我的 Django API 会去获取 Post.objects.all()。但是,我还想将 User.username 拉入响应中。我的理解是我可以通过运行来做到这一点:

posts=Post.objects.select_related('user').all()

当我posts.query从生成的 SQL 查询运行时,我可以看到正在拉入用户字段,但是当我尝试序列化此数据时似乎无法看到它们。我在这里错过了一些非常基本的东西吗?将相关数据与父数据一起序列化并与DRF Response一起发送出去的方法是什么?我已经尝试过本文中描述的方法,但是使用这种方法构建的序列化程序似乎没有为我返回相关数据:http: //ses4j.github.io/2015/11/23/optimizing-slow-django-rest-框架性能/

标签: djangodjango-modelsdjango-rest-frameworkdrf-queryset

解决方案


PostSerializer():
    user = UserSerializer()
    class Meta:
        model = Post
        fields = ('name', 'user')

推荐阅读