Django Rest framework 之 分页
- RESTful 规范
- django rest framework 之 认证(一)
- django rest framework 之 权限(二)
- django rest framework 之 节流(三)
- django rest framework 之 版本(四)
- django rest framework 之 解析器(五)
- django rest framework 之 序列化(六)
- django rest framework 之 分页(七)
- django rest framework 之 视图(八)
一、实例
分页有三种方式
- 普通分页,看第n页,每页显示m条数据;
- 切割分页,在n个位置,向后查看m条数据;
- 加密分页,这与普通分页方式相似,不过对url中的请求页码进行加密。
1、路由
<1>、主路由
from django.urls import include
from django.conf.urls import url
urlpatterns = [
url(r'^api/', include('api.urls', namespace='api') ),
]
<2>、app路由
from django.urls import include
from django.conf.urls import url
urlpatterns = [
url(r'^page/$', PageView.as_view()),
]
2、视图
在不使用django rest framework中的分页组件仍能够达到目的
from rest_framework import serializers
from rest_framework.views import APIView
from rest_framework.response import Response
class PagerSerializer(serializers.ModelSerializer):
class Meta:
model = Role
fields = "__all__"
class PageView(APIView):
def get(self, request , *args, **kwargs):
roles = Role.objects.get_queryset().order_by('id')
roles_ser = PagerSerializer(instance=roles, many=True)
return Response(roles_ser.data) # 只返回数据
返回结果

二、使用普通分页
1、自定义分页类
from rest_framework.pagination import PageNumberPagination
class MyPageNumberPagination(PageNumberPagination):
page_size = 2
max_page_size = 5
page_size_query_param = 'size'
page_query_param = 'page'
- page_query_param:表示url中的页码参数
- page_size_query_param:表示url中每页数量参数
- page_size:表示每页的默认显示数量
- max_page_size:表示每页最大显示数量,做限制使用,避免突然大量的查询数据,数据库崩溃
2、视图
class PagerSerializer(serializers.ModelSerializer):
class Meta:
model = Role
fields = "__all__"
class PageView(APIView):
def get(self, request , *args, **kwargs):
roles = Role.objects.get_queryset().order_by('id')
page = MyPageNumberPagination()
page_roles = page.paginate_queryset(queryset=roles, request=request, view=self)
roles_ser = PagerSerializer(instance=page_roles, many=True)
# return Response(roles_ser.data) # 只返回数据
return page.get_paginated_response(roles_ser.data) # 返回前后夜url
- 首先需要实例化我们定义的分页类
- 并且对实例化类进行传参控制
- 最后将分页后的对象作序列化
3、测试结果
<1>、正常测试
http://127.0.0.1:8000/api/page/

<2>、page、size测试
http://127.0.0.1:8000/api/page/?page=2&size=3 表示第二页,每页显示三条数据

三、使用普通分页
1、自定义分页类
from rest_framework.pagination import LimitOffsetPagination
class MyLimitOffsetPagination(LimitOffsetPagination):
default_limit = 2
limit_query_param = 'limit'
offset_query_param = 'offset'
max_limit = 5
- default_limit:表示默认每页显示几条数据
- limit_query_param:表示url中本页需要显示数量参数
- offset_query_param:表示从数据库中的第几条数据开始显示参数
- max_limit:表示每页最大显示数量,做限制使用,避免突然大量的查询数据,数据库崩溃
2、视图
class PagerSerializer(serializers.ModelSerializer):
class Meta:
model = Role
fields = "__all__"
class PageView(APIView):
def get(self, request , *args, **kwargs):
roles = Role.objects.get_queryset().order_by('id')
page = MyLimitOffsetPagination()
page_roles = page.paginate_queryset(queryset=roles, request=request, view=self)
roles_ser = PagerSerializer(instance=page_roles, many=True)
# return Response(roles_ser.data) # 只返回数据
return page.get_paginated_response(roles_ser.data) # 返回前后夜url
- 首先需要实例化我们定义的分页类
- 并且对实例化类进行传参控制
- 最后将分页后的对象作序列化
3、测试结果
<1>、测试结果一
http://127.0.0.1:8000/api/page/?

<2>、测试结果二
http://127.0.0.1:8000/api/page/?offset=2&limit=3表示从数据库中的第二条数据开始查询三条数据

四、使用加密分页
使用加密分页的原因:如果使用普通分页时,由于向用户提供了可选参数page,用户可以直接跳到数据分页之后的任意页码。但是这样做的后果就是,数据库的负载变大,返回结果的效率缓慢。但是一旦使用加密之后,虽然提供可选参数cursor,但是对页码进行加密,用户无法知道当前页,而是以上一页下一页的方式翻阅数据。有效避免了数据库的负荷。但是就需要向用户提供上一页下一页的url。
1、自定义分页类
from rest_framework.pagination import LimitOffsetPagination
class MyCursorPagination(CursorPagination):
cursor_query_param = 'cursor'
page_size = 2
ordering = 'id'
page_size_query_param = 'size'
max_page_size = 5
- default_limit:表示默认每页显示几条数据
- cursor_query_param:表示url中页码的参数
- page_size_query_param:表示每页显示数据量的参数
- max_page_size:表示每页最大显示数量,做限制使用,避免突然大量的查询数据,数据库崩溃
- ordering:表示返回数据的排序方式
2、视图
class PagerSerializer(serializers.ModelSerializer):
class Meta:
model = Role
fields = "__all__"
class PageView(APIView):
def get(self, request , *args, **kwargs):
roles = Role.objects.get_queryset().order_by('id')
page = MyCursorPagination()
page_roles = page.paginate_queryset(queryset=roles, request=request, view=self)
roles_ser = PagerSerializer(instance=page_roles, many=True)
return page.get_paginated_response(roles_ser.data) # 返回前后夜url
- 首先需要实例化我们定义的分页类
- 并且对实例化类进行传参控制
- 最后将分页后的对象作序列化
- 由于要想用户提供可用的上下页接口,所以只能用
return page.get_paginated_response(roles_ser.data)做返回
3、测试结果
<1>、测试结果一
http://127.0.0.1:8000/api/page/?

<2>、测试结果二
http://127.0.0.1:8000/api/page/?cursor=cD0z&size=3这里直接点击下一页url并追加每页显示数据量参数size

五、总结
三种分页中,普通分页与django中的分页基本没有区别。不过要做分页返回给前端数据,就要从数据库中取出数据,然后在做分页序列化。如果用户一下在前几页请求数据库中的最后几页数据,对查询数据库的时延,对数据库的负载较大,就会出现问题,这个时候就可以使用加密分页,限制用户的访问,只提供前一页和后一页的接口。
Django Rest framework 之 分页的更多相关文章
- django rest framework实现分页功能
在web开发中很多需求都需要实现分页功能,然而 Django Rest Framework 自带的分页功能,只能在 mixins.ListModelMixin and generics.Generic ...
- Django REST framework的分页
DRF分页组件 为什么要使用分页 我们数据表中可能会有成千上万条数据,当我们访问某张表的所有数据时,我们不太可能需要一次把所有的数据都展示出来,因为数据量很大,对服务端的内存压力比较大还有就是网络传输 ...
- Django REST framework 之分页,视图,路由,渲染器
1.分页 2.视图 3.路由 4.渲染器 1.分页 方法一: from django.shortcuts import render from rest_framework.versioning im ...
- Django rest framework 之分页
Django rest_framework 中分页可分为三类: PageNumberPagination:看第 n 页,每页显示 n 条数据 LimitOffsetPagination:在 n 个位置 ...
- Django Rest framework 之 序列化
RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...
- Django Rest framework 之 解析器
RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...
- Django Rest framework 之 版本
RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...
- Django Rest framework 之 节流
RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...
- Django Rest framework 之 权限
django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) django res ...
随机推荐
- Spring boot中使用log4j
我们知道,Spring Boot中默认日志工具为logback,但是对于习惯了log4j的开发者,Spring Boot依然可以很好的支持,只是需要做一些小小的配置功能.Spring Boot使用lo ...
- Linux巩固记录(9) keepalived+nginx搭建高可用负载分发环境
环境准备(继续服用hadoop节点) slave1 192.168.2.201(CentOs 7) slave2 192.168.2.202(CentOs 7) slave1 和 slave2 上 ...
- RegexHelper.js
var Validator = { VerityLib: { //验证字符串非空 IsNotEmpty: function (input) { if (input != '') { return tr ...
- Smart/400开发上手2: COBOL批处理程序处理过程
开发目的:1.建立DB2数据库表:2.建立逻辑视图:3.通过Cobol程序将一个源数据表的数据通过一定公式计算后导出到另一个目的数据库表源数据表:TIM3PF目的数据表:TIM4PF4.在AS400中 ...
- NPM(Node Package Manager,Node包管理器)
简介 每个Node应用都有一个包含该应用元数据的文件-package.json,包含应用名.版本号以及依赖等信息. 我们使用NPM从NPM库下载并安装第三方包. 所有下载的包以及其依赖都保存在node ...
- 【xsy2815】净空 大暴力
绝了场上居然没做这一题 题目大意:给你一个数$x=\Pi_{i=1}^{n}a_i!$. 你需要将x表示为$x=\Pi_{i=1}^{m}(c_i!)^{d_i}p$ 满足$p$无法再分解,且$(c_ ...
- NVIDIA GRID 和 NICE DCV 技术用于实现 Linux 和 Windows® 图形加速虚拟桌面
NVIDIA GRID 和 NICE DCV 技术用于实现 Linux 和 Windows® 图形加速虚拟桌面. NICE DCV: 满足 LINUX 和 WINDOWS 的远程 3D 通过 NICE ...
- oracle 11g RAC数据库监听配置相关
oracle RAC 监听配置基本和单实例的配置相同 11g之后 安装RAC的过程中,不需要执行netca来手动创建监听,在安装集群软件的时候,会自动创建监听程序: 而在DBCA建库的时候,又会自动创 ...
- Git for Windows之团队合作
1.先给项目添加一个成员 输入对方码云邮箱账号,添加成功. 2.登陆,将码云上面的项目克隆到本地 (1).设置全局参数 用户名和邮箱用于push和pull代码 (2).克隆目标项目地址 查看本地文件 ...
- Maven内置属性,pom属性
内置属性(Maven预定义,用户可以直接使用) ${basedir}表示项目根目录,即包含pom.xml文件的目录; ${version}表示项目版本; ${project.basedir}同${ba ...