自定义一个类:(https://www.runoob.com/python3/python3-class.html)
__init__(self):
#私有的东西外部不能调用
ORM中对于raw-queryset的分页是不能用分页器的,所以我们自建一个封装sql的分页类,调用即可
# 1.获取数据库连接 from django.db import connection class SqlPaginator(object): #python3可以不写,默认继承 #实现sql分页类: def __init__(self, sql, params, page_size): super().__init__() self.sql = sql #要查询的sql self.params = params #sql查询时候传递的参数 self.page_size = page_size #每页多少条数据 def page(self, now_page): """ 获取当前页: :param now_page: 页码 """ offset = (page - 1) * self.page_size # 偏移量:每页的首位置 sql = self.sql + ‘ limit %s offset %s‘ #不要漏了sql的空格 # 使用cursor: sql = (‘select `id`, `username`, `nickname` from `weibo_user`‘ ‘where `username` = %s‘ ) # 2。根据连接获取游标 cursor = connection.cursor() # 3。根据游标执行sql rest = cursor.execute(sql, [self.page_size, offset]) # 4。获取查询结果 rows = cursor.fetchall() return rows
在python3不写会默认调用:
原文:https://www.cnblogs.com/marvintang1001/p/11068386.html