------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------

本篇博客讲述如何在SpringBoot中整合PageHelper,如何实现带多个条件,以及PageInfo中的属性的中文解释(翻译)

一,jar包

        <!-- 分页插件 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.3</version>
</dependency>

二,注册Configuration插件

package cn.dawn.util;

/**
* Created by Dawn on 2018/6/24.
*/
import java.util.Properties; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import com.github.pagehelper.PageHelper; /*
* 注册MyBatis分页插件PageHelper
*/ @Configuration
public class MybatisConf {
@Bean
public PageHelper pageHelper() {
System.out.println("MyBatisConfiguration.pageHelper()");
PageHelper pageHelper = new PageHelper();
Properties p = new Properties();
p.setProperty("offsetAsPageNum", "true");
p.setProperty("rowBoundsWithCount", "true");
p.setProperty("reasonable", "true");
pageHelper.setProperties(p);
return pageHelper;
}
}

三,dao层接口

package cn.dawn.mapper;

import cn.dawn.entity.Sys_noteDetail;

import java.util.List;
import java.util.Map; /**
* Created by Dawn on 2018/4/16.
*/
public interface INoteDAO { /*笔记分页查询*/
public List<Sys_noteDetail> getOnePagenoteData(Map<String, Object> map) throws Exception; }

  做带条件分页最好是Map,因为特别容易整合智能标签,它的多条件就是Map传进来的

四,dao层xml配置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.dawn.mapper.INoteDAO"> <!--分页查询--> <select id="getOnePagenoteData" resultType="cn.dawn.entity.Sys_noteDetail">
SELECT * FROM sys_notedetail
<where>
<if test="dname!= null and dname!=''">
AND dname LIKE '%' #{dname} '%'
</if>
<if test="startdate!= null and startdate!=''">
AND dentrytime&gt;=#{startdate}
</if>
<if test="enddate!= null and enddate!=''">
AND dentrytime&lt;=#{enddate}
</if>
</where>
</select> </mapper>

五,调用PageHelper,真正使用它

package cn.dawn.service.impl;

import cn.dawn.entity.Sys_noteDetail;
import cn.dawn.mapper.INoteDAO;
import cn.dawn.service.INoteService;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* Created by Dawn on 2018/4/16.
*/
@Service("noteServiceImpl")
public class NoteServiceImpl implements INoteService{
@Resource(name = "INoteDAO")
private INoteDAO iNoteDAO; public PageInfo<Sys_noteDetail> getOnePagenoteData(Integer pageIndex, Integer pageSize, String dname, Date startdate, Date enddate) throws Exception {
/*创建分页工具类*/
PageHelper.startPage(pageIndex, pageSize);
Map<String,Object> map=new HashMap<String,Object>();
map.put("dname",dname);
map.put("startdate",startdate);
map.put("enddate",enddate);
List<Sys_noteDetail> docs = iNoteDAO.getOnePagenoteData(map);
PageInfo<Sys_noteDetail> pageInfo = new PageInfo<>(docs);
return pageInfo; } }

六,讲述一下PageInfo,方便调用

    //当前页
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 firstPage;
//前一页
private int prePage; //是否为第一页
private boolean isFirstPage = false;
//是否为最后一页
private boolean isLastPage = false;
//是否有前一页
private boolean hasPreviousPage = false;
//是否有下一页
private boolean hasNextPage = false;
//导航页码数
private int navigatePages;
//所有导航页号
private int[] navigatepageNums;

 

作者:晨曦Dawn

如果上方博客有错误,或者疑惑,请指出,感激不尽!!!!!!!!!!!!!!!!

最新文章

  1. js中的垃圾回收机制
  2. linux shell 逻辑运算符、逻辑表达式详解
  3. WIN7/8系统下程序接收不到WM_COPYDATA 消息的原因和解决
  4. Spring总结 0.概述
  5. 新安装mysql 第三方工具连接不上问题
  6. Java-JMS Bug记录
  7. 最全最详细:ubuntu16.04下内核编译以及设备驱动程序的编写(针对新手而写)
  8. 一句话理解字符编码(Unicode ,UTF8,UTF16)
  9. Windows 定时任务对数据库进行操作
  10. Yii2 console执行定时脚本
  11. Vue渐进式JavaScript 框架
  12. 51nod1268 和为K的组合(DFS)
  13. codeforce R 491 (div2)
  14. centos7救援模式--rescue模式
  15. jsp界面的继承与否剖析
  16. 快速了解CSS3当中的HSLA 颜色值怎么算
  17. React Native常用第三方组件汇总--史上最全 之一
  18. .net反编译工具
  19. MySQL中死锁
  20. 2018年浙江中医药大学程序设计竞赛 Solution

热门文章

  1. Struts2注解开发
  2. CentOS 安装 dokuwiki
  3. Pollard_rho 因数分解
  4. BZOJ1614:[USACO]Telephone Lines架设电话线(二分,最短路)
  5. 搭建nlp_server服务器
  6. 关于iframe里的子页面如何调取父级页面里的事件(子调父)
  7. Mark一下在模仿团购App搭建页面时犯的低级错误
  8. iOS数据存储类型 及 堆(heap)和栈(stack)
  9. java文件系统中的的NIO与IO
  10. Web—03-神器Photoshop