博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django REST framework 分页
阅读量:6332 次
发布时间:2019-06-22

本文共 1522 字,大约阅读时间需要 5 分钟。

 三种分页:根据页码、根据索引、根据加密

http://www.xx.com/courses/?page=1&size=10http://www.xx.com/courses/?offset=1&limit=10http://www.xx.com/courses/?page=sdf651sdf3
# 页码越大查询速度越慢,为什么以及如何解决?原因:页码越大,数据库需要扫描的行数越多,因为每次都是从0开始扫描。解决:     1、直接限制显示的页数,比如就显示100页,往后翻都不看了;     2、记录当前页数据ID的最小值和最大值,再次分页时,根据ID现行筛选,速度非常快。第一种简单粗暴,像百度、搜狗都是这样的;第二种就是使用了加密,即使懂 技术的也不知道?page=sdf651sdf3是第几页,不是你想跳到哪页就哪页的。
# urls.pyfrom django.conf.urls import urlfrom appxx import viewsurlpatterns = [    url(r"^authors/$", views.AuthorView.as_view()),]
# serializers.pyfrom appxx import modelsfrom rest_framework import serializersclass AuthorSerializer(serializers.ModelSerializer):    class Meta:        model = models.Author        fields = "__all__"
# views.pyfrom appxx import modelsfrom appxx import serializersfrom rest_framework.views import APIViewfrom rest_framework import paginationclass MyPageNumberPagination(pagination.PageNumberPagination):    page_query_param = "page"  # URL参数名称    page_size = 2  # 每页显示多少条数据    page_size_query_param = "size"  # page=2&size=3 --> 第二页显示4、5、6条的数据    max_page_size = 8  # 每页最多显示多少条数据class AuthorView(APIView):    def get(self, request):        authors_list = models.Author.objects.all()        my_page = MyPageNumberPagination()        authors_page = my_page.paginate_queryset(queryset=authors_list, request=request, view=self)        s = serializers.AuthorSerializer(authors_page, many=True)        return Response(s.data)        # return pnp.get_paginated_response(s.data)

 

转载于:https://www.cnblogs.com/believepd/p/10202618.html

你可能感兴趣的文章
C# Memcached缓存
查看>>
iOS开发NSLayoutConstraint代码自动布局
查看>>
正则表达式
查看>>
mysql [ERROR] Can't create IP socket: Permission denied
查看>>
PBRT笔记(4)——颜色和辐射度
查看>>
CustomView的手势缩放总结
查看>>
linux复制指定目录下的全部文件到另一个目录中,linux cp 文件夹
查看>>
CentOS yum安装mysql
查看>>
OceanBase笔记1:代码规范
查看>>
[Algorithms] Longest Increasing Subsequence
查看>>
MAC下GitHub命令操作
查看>>
springboot之filter/listener/servlet
查看>>
Thinkphp --- 去掉index.php
查看>>
Spring+SpringMVC+MyBatis深入学习及搭建(十一)——SpringMVC架构
查看>>
oracle故障解决
查看>>
tcpdump
查看>>
数据库内存结构
查看>>
利用Shell开发跳板机功能脚本案例
查看>>
51CTO的技术门诊谈OSSIM
查看>>
六年心路成长 —— 做自己
查看>>