使用PageHelper插件实现分页查询(详情)

1 、PageHelper介绍

PageHelper是国内非常优秀的一款开源的mybatis分页插件,它支持基本主流与常用的数据库,例如mysql、oracle、mariaDB等。

2、PageHelper的使用

(1)pom.xml依赖

(2)使用PageHelper Mapper文件的SQL语言可以直接使用无条件查询语句(以我本地电脑数据库的book表为例):

(3)在MyBatis的配置文件mybatis-config.xml中对PageHelper进行配置:

 上述配置的主体思想是对SQL语句的查询结果进行拦截。

     interceptor属性用于设置拦截的类名。

     pagerDialect用于指定SQL语言的方言,即项目使用的哪一款数据库。

     reasonable用于指定是否对数据进行合理化(输入的页码不符合页码规则的会自动修正)。

(4)mapper接口:

 (5)xml映射文件:

 很清楚可以看到上述的SQL查询是没有LIMIT分页语句的,执行后会自动生成一个带有LIMIT的SQL语句。

 (6)Service层:

PageHelper.startPage静态方法的调用

在你需要进行分页的MyBatis查询方法前调用PageHelper.startPage这个方法就行。

该方法PageHelper.startPage(page,pageSize),第一个参数为要查询的第几页,第二个参数为一页显示多少条数据。

(7)Controlelr层:

 (8)利用Apipost进行测试:

  返回结果:

 上述结果是一部分结果。

 (9)控制台输出日志:

 此时可以清楚的看到查询语句后是自动加上了LIMIT。

3、小结:

只是学到简单记录了一下PageHelper的使用方法,以后还会继续深入学习了解。最后给大家总结了生成分页对象的几个方法:

实例名bookPage在Service中有体现。

获取总页数: bookPage.getPages()

获取总记录数: bookPage.getTotal()

获取起始行号:bookPage.getStartRow()

获取结束行号:bookPage.getEndRow()

获取当前页码:bookPage.getPageNum()

获取本页数据:List<Book> bookPage.getResult()

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
PageHelper是一个用于实现分页功能的插件,它可以帮助我们简化分页查询的代码。引用中的内容介绍了如何在项目中使用PageHelper插件。 首先,在pom.xml文件中导入相关的依赖包,具体的配置如下所示: ```xml <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.2.3</version> </dependency> ``` 接下来,需要在application.properties文件中进行配置,配置项包括数据库方言、分页参数等,具体配置如下所示: ```properties # pagehelper配置 pagehelper.helper-dialect=mysql pagehelper.reasonable=true pagehelper.support-methods-arguments=true pagehelper.params=count=countSql ``` 在控制器中,我们可以通过使用@RequestMapping注解来定义一个分页查询的接口,具体的代码如引用所示。在这个接口中,我们可以通过@RequestParam注解来获取前端传递的分页参数pageNum和pageSize,并对这些参数进行非空判断和默认值设置。然后,我们可以调用业务逻辑层的方法进行分页查询,并将查询结果和分页信息传递到前端模板中进行展示。 最后,需要在HTML页面中进行相应的展示,具体的HTML代码可以根据具体需求来编写。关于PageHelper插件的版本问题,引用中提到了一个修改过的版本,用来解决条件查询时可能出现的异常问题。这个修改过的版本可以从特定的来源获取,但在中央仓库是无法直接下载到的。 综上所述,PageHelper是一个用于实现分页功能的插件,通过配置和调用相应的方法,我们可以在项目中使用PageHelper来简化分页查询的代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [使用PageHelper实现分页查询(详细)](https://blog.csdn.net/m0_48736673/article/details/124805124)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [pagehelper](https://download.csdn.net/download/anaitudou/10513398)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值