PageHelper

官方连接:https://github.com/pagehelper/Mybatis-PageHelper

官方文档对使用的方式、参数还有使用的安全性解释很清楚:

PageHelper会使用ThreadLocal获取到同一线程中的变量信息,所以在多线程环境下,各个ThreadLocal之间互相隔离,可以实现不同线程使用不同的数据源或执行不同的sql语句;

PageHelper利用这个机制通过拦截器获取到同一线程中的预编译好的sql语句,将其包装成具有分页功能的sql语句,并将其结果再次赋值给下一步操作,所以实际执行的sql语句就有了分页功能。值得注意的是,PageHelper只对紧跟着的第一个sql语句起作用,在使用PageHelper.startPage()静态方法的时候要小心。

SpringBoot项目中添加依赖到pom.xml文件:

<!--mybatis-->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.1</version>
</dependency>
<!--mapper-->
<dependency>
    <groupId>tk.mybatis</groupId>
    <artifactId>mapper-spring-boot-starter</artifactId>
    <version>1.2.4</version>
</dependency>
<!--pagehelper-->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.2.3</version>
</dependency>

配置在mybatis-config.xml文件里:

    <plugins>
        <plugin interceptor="com.github.pagehelper.PageHelper">
            <property name="dialect" value="mysql"/>
            <!--<property name="offsetAsPageNum" value="false"/>-->
            <!--<property name="rowBoundsWithCount" value="false"/>-->
            <!--<property name="pageSizeZero" value="true"/>-->
            <!--<property name="reasonable" value="false"/>-->
            <!--<property name="supportMethodsArguments" value="false"/>-->
            <!--<property name="returnPageInfo" value="none"/>-->
        </plugin>
    </plugins>

使用:

	        PageHelper.startPage(pageNumber,pageSize);
	        List<Supplier> listSupplier = supplierService.findAll();//做查询
	        System.err.println("listSupplier========"+listSupplier);
	        PageInfo<Supplier> pageInfo = new PageInfo<>(listSupplier);
	        System.err.println("pageInfo========"+pageInfo);
输出结果:

listSupplier========Page{count=true, pageNum=1, pageSize=5, startRow=0, endRow=5, total=8, pages=2, reasonable=false, pageSizeZero=false}
pageInfo========PageInfo{pageNum=1, pageSize=5, size=5, startRow=1, endRow=5, total=8, pages=2, list=Page{count=true, pageNum=1, pageSize=5, startRow=0, endRow=5, total=8, pages=2, reasonable=false, pageSizeZero=false}, prePage=0, nextPage=2, isFirstPage=true, isLastPage=false, hasPreviousPage=false, hasNextPage=true, navigatePages=8, navigateFirstPage=1, navigateLastPage=2, navigatepageNums=[1, 2]}
PageInfo类中的数据可以给前端使用,我想要查询的数据listSupplier好像被封装起来了。
PageInfo对象里有一个list属性,值与listSupplier相同都是Page对象的内容。
测试接口时输入地址:http://localhost/XXXXXi/admin/supplier/list?pageNumber=1&pageSize=5,输出的json数据中list值就是listSupplier实际的查询结果了。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值