版权声明:疏影横斜灬水清浅 https://blog.csdn.net/Goligory/article/details/81779030
分页这基本是必用的,但是一直以来自己定义的分页好用度也一般,并且大家用的分页千奇百怪,不如用pagehelper还是不错的
下面记录一下,基本框架我就不说了,这次单独集成pagehelper相关的东西
springboot集成pagehelper
引入jar
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.2</version>
</dependency>
在application.yml中加入配置
# 分页配置
pagehelper:
helper-dialect: mysql
reasonable: true
support-methods-arguments: true
params: count=countSql
举例应用:在service实现类中加入PageHelper,将当前页和每页条数附上
@Override
public PageBean getPage(Integer currentPage, Integer pageSize) {
PageHelper.startPage(currentPage, pageSize);
PageHelper.orderBy("id desc");
List<MtRecordPO> list = aMapper.getPage();
PageInfo pageInfo = new PageInfo(list);
PageBean pageBean = new PageBean(pageInfo);
System.out.println(list.size());
return pageBean;
}
包中PageInfo
下面是自定义PageBean,取得PageInfo中的想用的数据,这里有一个坑,web和service分布式服务的时候调用会有反序列化错误,可以new后set进去,注意空
public class PageBean<T> implements Serializable {
private static final long serialVersionUID = 1L;
private long totalCount; //总记录数
private List<T> list; //结果集
private int pages; // 总页数
public PageBean(PageInfo pageInfo){
this.totalCount = pageInfo.getTotal();//注意反序列化错误
this.list = pageInfo.getList();
this.pages = pageInfo.getPages();
}
public long getTotalCount() {
return totalCount;
}
public void setTotalCount(long totalCount) {
this.totalCount = totalCount;
}
public List<T> getList() {
return list;
}
public void setList(List<T> list) {
this.list = list;
}
public int getPages() {
return pages;
}
public void setPages(int pages) {
this.pages = pages;
}
}
sql语句:pagehelper已经帮你自动分页了,如若是条件查询,可以传入参数过去,sql中加入where条件语句即可
select <include refid="Base_Column_List2"/> from mtgg_test
web层取得PageBean返回给前端即可
springmvc+mybatis+pagehelper
导入包
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>4.1.6</version>
</dependency>
在appcontext-mybatis.xml中的<configuration>中配置插件配置如下
<plugins>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 4.0.0以后版本可以不设置该参数 -->
<property name="dialect" value="mysql"/>
<!-- 该参数默认为false -->
<!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->
<!-- 和startPage中的pageNum效果一样-->
<property name="offsetAsPageNum" value="true"/>
<!-- 该参数默认为false -->
<!-- 设置为true时,使用RowBounds分页会进行count查询 -->
<property name="rowBoundsWithCount" value="true"/>
<!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->
<!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->
<property name="pageSizeZero" value="true"/>
<!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->
<!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->
<!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->
<property name="reasonable" value="true"/>
<!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->
<!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->
<!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,orderBy,不配置映射的用默认值 -->
<!-- 不理解该含义的前提下,不要随便复制该配置 -->
<!-- <property name="params" value="pageNum=start;pageSize=limit;"/> -->
<!-- 支持通过Mapper接口参数来传递分页参数 -->
<property name="supportMethodsArguments" value="true"/>
<!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->
<property name="returnPageInfo" value="check"/>
</plugin>
</plugins>
不要忘了在appcontext-db.xml数据库配置所在文件中加载此插件 configLocation , 如下所示改成自己的路径
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="typeAliasesPackage" value="com.mtgg.entity"/>
<property name="mapperLocations" value="classpath*:mapper/*.xml"/>
<property name="configLocation" value="classpath:/config/appcontext-mybatis.xml"/>
</bean>
然后就可以分页查询了,PageBean还是用上面的,查询方式相同,亲测有效
其实查询出List放在PageInfo中后就实现分页了,其他就可以自定义了,你觉得什么方式好用就用什么方式,小代码是你的,你美你说的算,当然了,团队合作最好用同一种方式,不要总想着与众不同,这样代码不好看,维护也比较乱
记录一下用着方便