我是靠谱客的博主 欢喜羽毛,最近开发中收集的这篇文章主要介绍PageHelper的使用和一些错误总结,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

使用PageHelper犯的错

以为pagehelper很简单,直接将全部查询结果全部给与pageInfo就行了,结果犯了大错,,分页结果显示不出来,只是将全部结果显示出来。

解决方案:将SQL查询语句的返回值放在pageHelper.startPage(pageNum,pageSize)后面

PageHelper.startPage(pageNum, pageSize);
List<Video> videos = videoService.findAll();
PageInfo pageInfo = new PageInfo(videos);
pageHelper一些参数:
public class PageInfo<T> implements Serializable {
private static final long serialVersionUID = 1L;
//当前页
private int pageNum;
//每页的数量
private int pageSize;
//当前页的数量
private int size;
//由于startRow 和endRow 不常用,这里说个具体的用法
//可以在页面中"显示startRow 到endRow 共size 条数据"
//当前页面第一个元素在数据库中的行号
private int startRow;
//当前页面最后一个元素在数据库中的行号
private int endRow;
//总记录数
private long total;
//总页数
private int pages;
//结果集
private List<T> list;
//前一页
private int prePage;
//下一页
private int nextPage;
//是否为第一页
private boolean isFirstPage = false;
//是否为最后一页
private boolean isLastPage = false;
//是否有前一页
private boolean hasPreviousPage = false;
//是否有下一页
private boolean hasNextPage = false;
//导航页码数
private int navigatePages;
//所有导航页号
private int[] navigatepageNums;
//导航条上的第一页
private int navigateFirstPage;
//导航条上的最后一页
private int navigateLastPage;
}

pagehelper的使用

第一步:导入依赖
<!-- https://mvnrepository.com/artifact/com.github.pagehelper/pagehelper -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.10</version>
</dependency>
第二步:配置到spring整合配置文件applicationContext.xml中或者mybatis配置文件中
<!--配置sqlsessionFactoryBean-->
<!--在基础的 MyBatis 用法中,是通过 SqlSessionFactoryBuilder 来创建 SqlSessionFactory 的,而在 MyBatis-Spring 中,则使用 SqlSessionFactoryBean 来创建。-->
<bean name="sessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!--
<property name="configLocation" value="classpath:mybatis-config.xml.bak"></property>-->
<property name="plugins">
<set>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<props>
<!--配置数据库-->
<prop key="helperDialect">mysql</prop>
<!--当pageNum<1,默认查询一页
当pageNum>totalpage时,查最后一页-->
<prop key="reasonable">true</prop>
<!--支持接口传值-->
<prop key="supportMethonsArguments">true</prop>
</props>
</property>
</bean>
</set>
</property>
</bean>
第三步:controller层直接调用
 @RequestMapping("list")
public String list(@RequestParam(value = "pageNum",required = false,defaultValue = "1") Integer pageNum,
@RequestParam(value = "pageSize",required = false,defaultValue = "3") Integer pageSize,
Model model){
PageHelper.startPage(pageNum, pageSize);
List<Video> videos = videoService.findAll();
for (Video video : videos) {
System.out.println(video);
}
PageInfo pageInfo = new PageInfo(videos);
model.addAttribute("pageInfo",pageInfo);
return "/list.jsp";
}

自动的对PageHelper.startPage 方法下的第一个sql 查询进行分页
PageHelper.startPage(pageNum,pageSize);
//紧跟着的第一个select 方法会被分页
List videos = videoService.findAll();

也就是说再controller层PageHelper.startPage(pageNum,pageSize);语句后一定是紧跟查询语句。

最后

以上就是欢喜羽毛为你收集整理的PageHelper的使用和一些错误总结的全部内容,希望文章能够帮你解决PageHelper的使用和一些错误总结所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(37)

评论列表共有 0 条评论

立即
投稿
返回
顶部