springboot集成pagehelper和springmvc+mybatis+pagehelper的集成

版权声明:疏影横斜灬水清浅 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中后就实现分页了,其他就可以自定义了,你觉得什么方式好用就用什么方式,小代码是你的,你美你说的算,当然了,团队合作最好用同一种方式,不要总想着与众不同,这样代码不好看,维护也比较乱

记录一下用着方便

猜你喜欢

转载自blog.csdn.net/Goligory/article/details/81779030