PageHelper详解

PageHelper详解PageHelperpa 是 mybatis 提供的分页插件 目前支持 Oracle Mysql MariaDB SQLite Hsqldb PostgreSQL 六种数据库 使用方法原始样式 每页显示多条数据 现在的需求是每页显示 4 条数据后端导入依赖依赖 pagehelper 开始分页 Service 方法调用 SQL 查询前添加 PageHelper startPagePag startPage 1 20 这里有两个参数 分别为 page 1 rows 2

PageHelper

pagehelper是mybatis 提供的分页插件,目前支持Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库。

使用方法

原始样式,每页显示多条数据,现在的需求是每页显示4条数据

在这里插入图片描述

后端

导入依赖

依赖: pagehelper

开始分页

Service 方法调用SQL查询前添加 PageHelper.startPage

PageHelper.startPage(1, 20); 

这里有两个参数,分别为:page=1,rows=20。默认请求第一页,每页显示20条数据

原理

首先是在Mybatis里面配置了分页拦截器(PageInterceptor),即在执行相关Sql之前会拦截做一点事情;

这里通过setLocalPage()方法,将分页信息保存在当前线程中。查询方法与之处于同一个线程中,共享ThreadLocal中的数据。

selectlist查询之后赋值给的List list。这个list是Page 类型。

再将list放到PageInfo<>中即可。

查询

List<TbItem> list = tbItemMapper.selectByExample(tbItemExample); 

分页结果与展示

取分页信息,使用PageInfo对象获取分页信息。

 PageInfo<TbItem> pageInfo = new PageInfo<>(list); System.out.println("总记录数:"+pageInfo.getTotal()); System.out.println("总页数:"+pageInfo.getPages()); System.out.println("一页的大小:"+pageInfo.getSize()); 
PageInfo里面的属性
 private int pageNum;//当前页码 private int pageSize;//设置每页多少条数据 private int size;//当前页有多少条数据 private int startRow;//当前页码第一条数据的 private int endRow;//当前页码的开始条 private int pages;//当前页码结束条 private int prePage;//上一页(页面链接使用) private int nextPage;//下一页(页面链接使用) private boolean isFirstPage;//是否为第一页 private boolean isLastPage;//是否为最后一页 private boolean hasPreviousPage;//是否有前一页 private boolean hasNextPage;//是否有下一页 private int navigatePages;//导航页码数(就是总共有多少页) private int[] navigatepageNums;//导航页码数(就是总共有多少页),可以用来遍历 private int navigateFirstPage;//首页号 private int navigateLastPage;//尾页号 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233227.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java Web项目 慧心人力资源管理系统[通俗易懂]

    Java Web项目 慧心人力资源管理系统[通俗易懂]美和易思JavaWeb机试试题题目:慧心人力资源管理系统文档下载:https://download.csdn.net/download/weixin_44893902/16336711实现代码下载:目录一、语言和环境二、实现功能三、数据库设计四、具体要求及推荐实现步骤五、评分标准六、实现代码一、语言和环境实现语言:JAVA语言。 环境要求:MyEclipse/Eclipse+Tomcat+MySql。 使用技术:Jsp+Servlet+Jav..

    2022年5月28日
    32
  • 图数据的自监督学习介绍

    图数据的自监督学习介绍深度学习在解决许多复杂的机器学习问题方面一直是一个有趣的课题,特别是最近在图数据方面。然而,大多数的解决方案要么是监督或半监督,高度依赖于数据中的标签,导致过拟合和整体鲁棒性较弱。自监督学习(Self-SupervisedLearning,SSL)是一种很有前途的解决方案,它从无标记数据中挖掘有用的信息,使其成为图数据领域中一个非常有趣的选择。为什么自监督学习更适合图形数据?SSL有助于理解图形数据中存在的结构和属性信息,使用标记数据时可能会忽略这些信息对于现实世界的数据,获取带标签的图形数据非常

    2025年11月14日
    5
  • mysql数据库去重[通俗易懂]

    mysql数据库去重[通俗易懂]2019独角兽企业重金招聘Python工程师标准>>>…

    2022年10月1日
    4
  • L2-014列车调度(最长上升子序列LIS)[通俗易懂]

    L2-014列车调度(最长上升子序列LIS)[通俗易懂]原题链接最长上升子序列火车站的列车调度铁轨的结构如下图所示。两端分别是一条入口(Entrance)轨道和一条出口(Exit)轨道,它们之间有N条平行的轨道。每趟列车从入口可以选择任意一条轨道进入,最后从出口离开。在图中有9趟列车,在入口处按照{8,4,2,5,3,9,1,6,7}的顺序排队等待进入。如果要求它们必须按序号递减的顺序从出口离开,则至少需要多少条平行铁轨用于调度?输入格式:输入第一行给出一个整数N (2 ≤ N ≤10​5​​ ),下一行给出从1到N的整数序号的一个重排列。数字间

    2022年8月8日
    7
  • Oracle SQL脚本学习6

    Oracle SQL脚本学习6

    2021年8月29日
    71
  • 使用433MHz RF模块制作一艘简易的Arduino遥控小船

    使用433MHz RF模块制作一艘简易的Arduino遥控小船原文地址:https://www.yiboard.com/thread-1567-1-1.html使用433MHzRF模块制作一艘简易的Arduino遥控小船https://www.yiboard.com/forum.php?mod=viewthread&tid=1567&fromuid=2110本篇文章中,我们将制作一个远程控制的Arduino小船,可以使用433MHzRF无线模块进行控制。我们将制作自己的433MHz发射器和接收器模块,使用自制遥控器来控制这艘小船。对于远程控

    2026年1月30日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号