Django-DRF接口查询.count()执行缓慢问题

目前就想到了这两种

 

drf框架返回接口数据的时候返回count接口数据随着数据的增多查询缓慢!

1. 不返回总数据,前端采用下拉刷新方式获取

2. 主键采用int类型,每次返回最后一条数据id数即为总数(first().id - last().id + 1)

复制代码
from collections import OrderedDict

from rest_framework.pagination import LimitOffsetPagination
from rest_framework.response import Response


class CustomLimitOffsetPagination(LimitOffsetPagination):
    """自定义分页器:优化大数据查询缓慢"""

    def get_count(self, queryset):
        try:
            return queryset.first().id - queryset.last().id + 1
        except (AttributeError, TypeError):
            return len(queryset)

    def get_paginated_response(self, data):
        return Response(OrderedDict([('count', self.count), ('results', data)]))
复制代码

 

posted @   一石数字欠我15w!!!  阅读(84)  评论(2编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 如何使用 Uni-app 实现视频聊天(源码,支持安卓、iOS)
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
点击右上角即可分享
微信分享提示