如何限制GeoDjango Postgis Django-rest-framework查询的条目数量? [英] How to limit number of entries from GeoDjango Postgis django-rest-framework query?

查看:14
本文介绍了如何限制GeoDjango Postgis Django-rest-framework查询的条目数量?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我已经通过this tutorial构建了基本的Django映射功能,但Python一直在消耗32 GB的RAM和/或浏览器崩溃,大概是因为查询不限于前n个结果,并且数据库有数百万个条目。

我的vietsets.py;:

from rest_framework import viewsets
from rest_framework_gis import filters

from core.models import Tablename
from core.serializers import MarkerSerializer

class MarkerViewSet(viewsets.ReadOnlyModelViewSet):

    bbox_filter_field = "geom"
    filter_backends = (filters.InBBoxFilter,)
    queryset = Tablename.objects.all()
    serializer_class = MarkerSerializer

我认为InBBoxFilter需要详细说明,但the docs似乎没有提到任何进一步的选择。文档说,如果您正在使用其他筛选器,您将希望在您的视图中包含其他筛选器后端,例如filter_backends = (InBBoxFilter, DjangoFilterBackend,),但我只想限制InBBoxFilter已经提供的功能的结果数量。我可以编写某种DjangoFilterBackend来限制结果吗?或者这是通过Django-REST-框架功能来解决的最好方式?

使用大型数据库时,我如何告诉它限制结果数或以其他方式提高性能?

推荐答案

更改为下面。 REST框架_gis支持此分页。

from rest_framework import viewsets
from rest_framework_gis import filters
from rest_framework_gis.pagination import GeoJsonPagination

from core.models import Tablename
from core.serializers import MarkerSerializer


class MarkerViewSet(viewsets.ReadOnlyModelViewSet):
    bbox_filter_field = "geom"
    filter_backends = (filters.InBBoxFilter,)
    queryset = Tablename.objects.all()
    serializer_class = MarkerSerializer
    pagination_class = GeoJsonPagination

您可以升级服务器或限制结果(分页)。 最合适的分页方式取决于您的要求。 您可以按某种规则或其他方式对区域进行分组。

这篇关于如何限制GeoDjango Postgis Django-rest-framework查询的条目数量?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆