如何使用查询参数过滤DRF中的对象?

2024-06-13 10:51:49 发布

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

我尝试通过自己的字段“name”而不是pk来查询课程。 在查询时,路径应该是什么

pk提供的所有基本CRUD和查询都可以很好地使用此代码

在此我附上了所有相关文件:

型号.py

from django.db import models

# Teacher = opettaja in Finnish
class Opettaja(models.Model):
    nimi = models.CharField(max_length=100, default='')
    puhelin = models.CharField(max_length=20, default='')

    class Meta:
        ordering = ['nimi']

# Course = kurssi in Finnish
class Kurssi(models.Model):
    nimi = models.CharField(max_length=100, default='')
    laajuus = models.IntegerField()
    opettaja = models.ForeignKey(Opettaja, on_delete=models.CASCADE)

    class Meta:
        ordering = ['nimi']

序列化程序.py

from rest_framework import serializers
from .models import Opettaja, Kurssi

class OpettajaSerializer(serializers.ModelSerializer):
    class Meta:
        model = Opettaja
        fields = ['id', 'nimi', 'puhelin']

class KurssiSerializer(serializers.ModelSerializer):
    class Meta:
        model = Kurssi
        fields = ['id', 'nimi', 'laajuus', 'opettaja']

url.py

from django.urls import include,path
from rest_framework import routers
from . import views

router = routers.DefaultRouter()
router.register(r"opettaja", views.OpettajaViewSet)
router.register(r"kurssi", views.KurssiViewSet, "nimi")

# My app is simply named as app in this project
urlpatterns = [
    path("api/", include((router.urls, "app"))),
]

视图.py

from rest_framework import viewsets from .models import Opettaja, Kurssi from .serializers import OpettajaSerializer, KurssiSerializer

class OpettajaViewSet(viewsets.ModelViewSet):
    queryset = Opettaja.objects.all()
    serializer_class = OpettajaSerializer

class KurssiViewSet(viewsets.ModelViewSet):
    queryset = Kurssi.objects.all()
    serializer_class = KurssiSerializer
    def get_queryset(self):
        queryset = Kurssi.objects.all()
        nimi = self.request.query_params.get("nimi")
        if nimi is not None:
            nimi = nimi
        return queryset

我尝试通过自己的字段“name”而不是pk来查询课程。 在查询时,路径应该是什么


Tags: infrompyimportmodelsmetaclassqueryset
1条回答
网友
1楼 · 发布于 2024-06-13 10:51:49

试试这个

def get_queryset(self):
    queryset = Kurssi.objects.all()
    nimi = self.request.query_params.get("nimi")
    if nimi is not None:
        queryset = queryset.filter(nimi=nimi)
    return queryset

您不必为此更改URL路径,URL应该是

api/kurssi?nimi=some_name

相关问题 更多 >