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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 常见的ARM集成开发环境

    常见的ARM集成开发环境1.ARMSDT:是ARM公司为方便用户在ARM芯片上进行应用软件开发而推出的一整套开发工具。到ARMSDT2.5.1,ARM宣布推出ARMADS1.0取代了ARMSDT,不再对ARMSDT进行维护。ARMSDT支持的ARM处理器最高到包括ARM9在内的所有ARM处理器。配合Angel驻留程序和JTAG仿真器,用户使用可方便的使用ARMSDT进行应用程序的开发。2.ARM

    2022年5月18日
    38
  • vue格式化时间戳_日期格式转换

    vue格式化时间戳_日期格式转换第一步:下载安装第三方组件:npminstallmoment–save第二步:在你需要格式化时间的页面引入moment组件importmomentfrom’moment’第三步:然后配合我们element-ui,在元素中加入:formatter<el-table-columnprop=”add_time”label=”创建时间”:formatter=”dateFormat”width=”200px”></el-table-column&gt

    2022年9月25日
    4
  • oracle修改用户密码永不过期_oracle查看密码过期时间

    oracle修改用户密码永不过期_oracle查看密码过期时间Oracle用户登录密码过期的修改1、查看用户的proifle是哪个,一般是default:sqlgt;SELECTusername,PROFILEFROMdba_useOracle用户登录密码过期的修改1、查看用户的proifle是哪个,,一般是default:sql>SELECTusername,PROFILEFROMdba_users;2、查看指定概要文件(如defau…

    2022年7月28日
    34
  • 性能测试平台ngrider

    性能测试平台ngrider一 ngrider 简介 nGrinder 是 NHN 公司基于 Grinder 开发的开源性能测试平台 1 b s 架构 非常易用 有友好简洁的用户界面 能在 Windows linux mac 系统运行 2 具有 controller agent 分布式结构的强大的压力测试工具 能够执行性能测试和监控目标服务器 并保存这些数据生成测试报告 通过动态图和数据表的形式展示出来 3 可以自动生成 jython 和 groovy 语言的脚本 当然 如果想执行一些比较复杂场景的性能测试 测试人员也可以自己编写脚本 导入进来 二 n

    2025年6月6日
    3
  • 升降压电路的工作原理

    升降压电路的工作原理1.升压电路也叫自举电路,是利用自举升压二极管,自举升压电容等电子元件,使电容放电电压和电源电压叠加,从而使电压升高,有的电路升高的电压能达到数倍电源电压。开关直流升压电路(即所谓的boost或者step-up电路)原理,theboostconverter,或者叫step-upconverter,是一种开关直流升压电路,它可以是输出电压比输入电压高。基本电路图如图所示假定那个开关(三极管或者mos管)已经断开了很长时间,所有的元件都处于理想状态,电容电压等于输入电压。下面要分充电和放电两个部分来

    2022年6月20日
    63
  • 基于Spring Cloud项目实战

    (2018年10月2日,从git上移到这里)通过案例学习了基于Springcloud进行web微服务项目的开发,干货很多。Springcloud体系提供了完整的微服务开发的解决方案,整合了多个优秀组件,能够很好的帮助我们提高开发效率。在此做以下总结。SpringCloud简介SpringCloud是一个基于SpringBoot实现的微服务架构开发工具。它…

    2022年4月6日
    68

发表回复

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

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