序列化程序关系在Django Rest框架中不起作用

2024-10-03 05:26:51 发布

您现在位置:Python中文网/ 问答频道 /正文

我的应用程序中有两个模型。以下是我在models.py中的代码:

from django.db import models

class TblDivision(models.Model):
    strdivisionname = models.CharField(db_column='strDivisionName', max_length=35, blank=True, null=True)  # Field name made lowercase.

    class Meta:
        db_table = 'Tbl_Division'

class TblPosition(models.Model):
    strpositionname = models.CharField(db_column='strPositionName', max_length=30, blank=True, null=True)  # Field name made lowercase.

    class Meta:
        db_table = 'Tbl_Position'

class TblEmployee(models.Model):
    strname = models.CharField(db_column='strName', max_length=70, blank=True, null=True)  # Field name made lowercase.
    stremployeeid = models.CharField(db_column='strEmployeeID', max_length=10, blank=True, null=True)  # Field name made lowercase.
    bitactive = models.BooleanField(db_column='bitActive', blank=True, null=True)  # Field name made lowercase.
    intdivision = models.ForeignKey(TblDivision, db_column='intDivision',related_name='division', on_delete=models.CASCADE)
    intposition = models.ForeignKey(TblPosition, db_column='intPosition',related_name='position', on_delete=models.CASCADE)

    class Meta:
        db_table = 'Tbl_Employee'

这是我在serializer.py中的代码:

from rest_framework import serializers
from .models import TblEmployee,TblDivision

class DivisionSerializer(serializers.ModelSerializer):
    class Meta:
        model = TblDivision
        fields=['id','strDivisionName']     


class EmployeeSerializer(serializers.ModelSerializer):
    division = DivisionSerializer(many=True, read_only=True)

    class Meta:
        model = TblEmployee
        fields=['id','strname','stremployeeid','intdivision','division']        

这是我的{}:

from .models import TblEmployee
from .serializer import EmployeeSerializer,DivisionSerializer

from rest_framework import status
from rest_framework.response import Response
from rest_framework.decorators import api_view

@api_view(["GET", ])

def api_list_employee_view(request):
    try:
        employee_list = TblEmployee.objects.all()
    except TblEmployee.DoesNotExist:
        return Response(status=status.HTTP_404_NOT_FOUND)

    if request.method == "GET":
        serializer = EmployeeSerializer(employee_list, many="true") 
        dataEmployee = serializer.data
        return Response(dataEmployee)

我想创建一个简单的API,以JSON格式显示来自员工模型及其部门名称的数据。但是API没有显示strDivisionName字段。它只显示来自Employee模型的字段。有人能解释一下我的问题和解决办法吗?我还是Django Rest Framewrok的新手。谢谢你


Tags: namefromimporttruefielddbmodelscolumn
3条回答

我的朋友,你的序列化程序代码出错了!您必须提供与您在模型中输入的名称完全相同的名称(在您编写的模型中:“strdivisionname”和在序列化程序中:“strdivisionname”)

使用以下代码更新序列化程序:

from rest_framework import serializers
from .models import TblEmployee,TblDivision

class DivisionSerializer(serializers.ModelSerializer):
    class Meta:
        model = TblDivision
        fields=['id','strdivisionname']   

在字段中,您显示了错误的字段名。它是strIDvisionName而不是strIDvisionName

因为您使用EmployeeSerializer序列化了TblEmployee实例!在您的EmployeeSerializer中没有任何strdivisionname字段!你必须在你的模型上用它做一个外键,对吗

相关问题 更多 >