'Users' 对象没有属性 'values' django rest 框架

'Users' object has no attribute 'values' django rest framework

我在使用连接表序列化数据时遇到问题。我这样做对吗?我只是 django 的新手。

这是我的 models.py

from django.db import models
from django.contrib.auth.models import AbstractBaseUser

class Agency(models.Model):
    agency_id = models.CharField(primary_key=True, max_length=50)
    agency_shortname = models.CharField(max_length=20, blank=True, null=True)
    agency_longname = models.CharField(max_length=255, blank=True, null=True)
    date_created = models.DateTimeField(blank=True, null=True)

        class Meta:
            managed = False
            db_table = 'agency'

class Users(AbstractBaseUser):
    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = []
    user_id = models.CharField(primary_key=True, max_length=50)
    first_name = models.CharField(max_length=50, blank=True, null=True)
    middle_name = models.CharField(max_length=50, blank=True, null=True)
    last_name = models.CharField(max_length=50, blank=True, null=True)
    username = models.CharField(unique=True, max_length=50, blank=True, null=True)
    password = models.CharField(max_length=100, blank=True, null=True)
    agency = models.OneToOneField(Agency, models.DO_NOTHING)
    date_created = models.DateTimeField(blank=True, null=True)
    active = models.CharField(max_length=8)
    login_status = models.CharField(max_length=6)
    last_login = models.DateTimeField(blank=True, null=True)

    class Meta:
        managed = False
        db_table = 'users'

然后在我的serializers.py

   from rest_framework import serializers
   from .models import Users, Agency

   class UserDetailSerializer(serializers.ModelSerializer):
       class Meta: 
           model = Users
           fields = '__all__'

   class AgencyDetailSerializer(serializers.ModelSerializer):
       agency_id = UserDetailSerializer()
       class Meta:
           model = Agency
           fields = ['agency_id','agency_shortname','agency_longname']

和我的views.py

   from rest_framework.decorators import api_view, permission_classes
   from rest_framework.response import Response
   from .serializers import UserDetailSerializer
   from .models import Users, Agency
   from rest_framework.permissions import IsAuthenticated

   @api_view(['GET'])
   @permission_classes([IsAuthenticated])
   def userData(request):
       username = request.GET.get('username')
       r_type    = request.GET.get('type')

       user = Users.objects.get(username=username).values('user_id','first_name','middle_name','last_name','username','email','agency__agency_id','agency__agency_shortname','agency__agency_longname')
       user_serializer = UserDetailSerializer(user, many=False)

       return Response(user_serializer.data)

我收到 'Users' object has no attribute 'values' 的错误,似乎是什么问题?我正在使用 vue.js 和 django rest 框架构建基于 api 的应用程序。非常感谢

get 查询集没有 values 属性,使用 filter 代替。

user = Users.objects.filter(username=username).values(...)

关于你的情况,使用 get 就足够了,像这样自定义你的 Serializer:

class UserDetailSerializer(serializers.ModelSerializer):
    class Meta: 
        model = Users
        fields = '__all__'
    agency = AgencyDetailSerializer(many=False, read_only=True)

因为值不是模型对象的属性。您可以在 queryset 对象上调用值。类似于:

user = Users.objects.filter(username=username).values('user_id','first_name','middle_name','last_name','username','email','agency__agency_id','agency__agency_shortname','agency__agency_longname')

注意:不需要调用values,只需将这一行改为:

   from rest_framework.generics import get_object_or_404

   ...
   user = get_object_or_404(Users, **dict(username=username))
   user_serializer = UserDetailSerializer(user)
   ...

因为序列化程序本身会为您处理。