Python自动化运维开发----基础(十四)Mysql数据
admin
2023-01-29 09:20:03
0

后端数据库分页是根据limit实现的

第一种写法: limit 每页的个数 offset 起始位置

select id,name,sex,tel,addr from user limit 1 offset 1;
select * from student limit pageSize offset (pageNumber-1)*pageSize

Python自动化运维开发----基础(十四)Mysql数据

第二种写法: limit 起始位置,每页的个数

select id,name from user limit 1,2;
select * from studnet limit (pageNumber-1)*pageSize,pageSize

Python自动化运维开发----基础(十四)Mysql数据

当数据量比较大的时候分页采用子查询的方式

select id,name from user where id >= (select id from user order by id limit 1,1) limit 2;
select id,name from user where id >= (select id from user order by id limit 起始位置,1) limit 每页的个数;

Python自动化运维开发----基础(十四)Mysql数据

Python代码中实现后台数据分页

views.py文件

Page()函数是mypage.py里边类的方法

user_count() 是获取mysql 数据总数的方法

def index(request):
    page_num = request.GET.get("page")
    login_user = request.session.get('user')
    count = user_count()
    per_page = 2
    page_obj = Page(page_num, count,url_prefix="/users/",per_page=2, max_page=4,)
    page_num = page_obj.num
    users = mysql_page(per_page,page_num)
    page_html = page_obj.page_html()
    return render(request,'static/index.html',{"users": users,"login_user": login_user,"page_html": page_html})

mypage.py

class Page():

    def __init__(self, page_num, total_count, url_prefix, per_page, max_page=4):
        """
        :param page_num: 当前页码数
        :param total_count: 数据总数
        :param url_prefix: a标签href的前缀
        :param per_page: 每页显示多少条数据
        :param max_page: 页面上最多显示几个页码
        """
        self.url_prefix = url_prefix
        self.max_page = max_page
        # 每一页显示多少条数据
        # 总共需要多少页码来展示
        total_page, m = divmod(total_count, per_page)
        if m:
            total_page += 1
        self.total_page = total_page

        try:
            page_num = int(page_num)
            # 如果输入的页码数超过了最大的页码数,默认返回最后一页
            if page_num > total_page:
                page_num = total_page
        except Exception as e:
            # 当输入的页码不是正经数字的时候 默认返回第一页的数据
            page_num = 1
        self.page_num = page_num


        # 页面上总共展示多少页码
        if total_page < self.max_page:
            self.max_page = total_page

    @property
    def num(self):
        return self.page_num

    def page_html(self):
        # 自己拼接分页的HTML代码
        html_str_list = []
        # 加上第一页
        html_str_list.append('
  • 首页
  • '.format( self.url_prefix))         # 判断一下 如果是第一页,就没有上一页         if self.page_num <= 1:             html_str_list.append('«'.format(self.page_num-1))         else:             # 加一个上一页的标签             html_str_list.append('
  • «
  • '.format( self.url_prefix, self.page_num-1))         for i in range(1,self.total_page+1):             # 如果是当前页就加一个active样式类             if i == self.page_num:                 tmp = '{1}'.format(self.url_prefix, i)             else:                 tmp = '
  • {1}
  • '.format( self.url_prefix, i)             html_str_list.append(tmp)         # 加一个下一页的按钮         # 判断,如果是最后一页,就没有下一页         if self.page_num >= self.total_page:             html_str_list.append('»')         else:             html_str_list.append('
  • »
  • '.format( self.url_prefix, self.page_num+1))         # 加最后一页         html_str_list.append('
  • 尾页
  • '.format( self.url_prefix, self.total_page))         page_html = "".join(html_str_list)         return page_html

    models,py 

    def mysql_page(per_page,page):
        start = (page - 1 ) * per_page
        sql = 'select id,name,sex,age,tel,addr,role from user where id >= \
                              ( select id from user order by id limit %s,1)limit %s'
        args = (start,per_page)
        conn = MySQLdb.connect(host=MYSQL_HOST, port=MYSQL_PORT, user=MYSQL_USER, passwd=MYSQL_PASSWORD, db=MYSQL_DB,
                               charset='utf8mb4')
        cursor = conn.cursor()
        cursor.execute(sql, args)
        lines = cursor.fetchall()
        users = []
        for line in lines:
            users.append({
                'id': line[0],
                'name': line[1],
                'sex': '男' if line[2] else '女',
                'age': line[3],
                'tel': line[4],
                'addr': line[5],
                'role': line[6]
            }
            )
        cursor.close()
        conn.close()
        return users


    相关内容

    热门资讯

    德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
    理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
    白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
    人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
    医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
    天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
    卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
    男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
    商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
    过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...