繁体   English   中英

如何使用 Django Rest 过滤器限制查询结果

[英]How to limit query results with Django Rest filters

我正在研究使用Django Rest Framework构建的 api。 我已经定义了几个model类,我还创建了一些过滤器来应用在指定的api-endpoints中发生的某些查询。

我想在申请LIMIT queryset ,但我宁愿不使用Django的符号前Entry.objects.all()[:5] 相反,我希望能够从与模型关联的过滤器内部应用限制。

直到现在我还没有找到任何解决方案。 我想我应该找到一种方法来定义具有默认值的过滤器,这会导致不限制查询集,并且如果请求到达端点并包含诸如?filter=10则查询集应限制为前 10 个.

您可以使用 Django Rest Framework 分页。 pagination_class LimitOffsetPagination使您能够限制 query_param 中返回条目的数量。

http://www.django-rest-framework.org/api-guide/pagination/

您可以扩展或自定义drf 中可用的分页类

  class UserSpecificPagination(LimitOffsetPagination):
      def get_limit(self, request):
          if logic_met(request.user):
            self.max_limit = custom_limit
      return super(UserSpecificPagination, self).get_limit(request)

ListAPIView或 DRF 设置中将类设置为pagination_class

您应该使用 django-rest 中的分页 API

http://www.django-rest-framework.org/api-guide/pagination/

查看limit选项

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM