Django Rest Framework DRF一句代码实现分页之原理分析 ---LimitOffsetPagination篇
一句代码实现分页?
前段时间在网上搜例子,对着葫芦画瓢,通过重写一些方法等实现了分页,略复杂。其实有更简单的方式,先看怎么用一句代码实现分页?
models.py:
class LoginPrison(models.Model):
id = models.AutoField(primary_key=True)
account_id = models.IntegerField()
occured_time = models.DateTimeField()
type = models.IntegerField()
class Meta:
db_table = 'login_prison'
ordering = ('-occured_time',)
class LoginPrisonSerializer(serializers.ModelSerializer):
class Meta:
model = LoginPrison
fields = '__all__'
router = routers.SimpleRouter()
router.register(r'TV', views.TestViewSet)
urlpatterns = router.urls
class TestViewSet(mixins.RetrieveModelMixin,
mixins.DestroyModelMixin,
mixins.ListModelMixin,
viewsets.GenericViewSet):
queryset = LoginPrison.objects.all()
serializer_class = LoginPrisonSerializer
pagination_class = LimitOffsetPagination
其实上面代码分页的核心就一句:pagination_class = LimitOffsetPagination
(当然还有其他分页类,此处只介绍一个类即可,因为原理类似)
看看postgresql数据库:
然后运行程序看下效果:(注意:offset是起始查询位置)
views.py中只是继承了几个类,重写了几个类属性,一个方法都没写就轻轻松松完成了分页,好神奇,下面跟踪下代码,记录下过程:
代码分解
前端输入http://120.79.84.147:3389/show/TV/?limit=4&offset=1,url解析对应到views.TestViewSet。
下面再次看看views.py:
class TestViewSet(mixins.RetrieveModelMixin,
mixins.DestroyModelMixin,
mixins