实现分页  这里提供两种方式  一种是传统的分页方式  一种是基于pageHelper插件 实现的分类     推荐使用后者

前者是一般开发的方式   思路  先手动创建一个 pageUtil 工具 用于记录 分页的各种信息  然后使用繁琐的方式去调用数据

pageUtil  类  可以根据需要自定义

package com.imooc.project.util;
/**
* 这里使用 传统的 方法 进行 分页 设计 需要建立一个 用于分页的信息类 用来存放分页的信息
* @author lqf
*
*/ import java.util.List; public class PageUtil {
private int currentPageNum; //当前要看那一页 private int pageSize=10 ; //每页显示的条数 private int totalSize; //总记录条数 private int startIndex; //查询开始记录的索引 limit ? ? limit的使用 private int totalPageNum; //总页数 private int nextPageNum; //下一页 private int prePageNum; //上一页 private List records; //当前页的 记录集 List<User> records 返回的是 每一页中user的 集合 //用于显示 页面上的 导航的 页数 用户可以自定义
private int startPageNum; // 起始页
private int endPageNum ; // 结束页
private String url ;
//使用构造方法。 传递 必要的 俩个参数 第一个是 页码 第二个是总记录条数 就可以获得 其他所有的数据 public PageUtil(int currentPageNum,int totalrecords)
{
this.currentPageNum=currentPageNum;
this.totalSize= totalrecords ;
/*
* 1 0 - 10 limit(0,10)
* 2 10 - 20 limit(10,10)
* 3 20 -30 limit(20,30)
* (当前页-1 )*10 = 该页索引值 startIndex
* (currentPageNum-1)*pageSize
*/ //计算开始记录的索引
startIndex=(currentPageNum-1)*pageSize;
//计算总页数
totalPageNum=totalSize%pageSize==0?totalSize/pageSize:totalSize/pageSize+1;
//计算开始和结束页号 这个根据自身可设计 1 2..9
if(totalPageNum>9)
{
startPageNum=currentPageNum-4;
endPageNum=currentPageNum+4; if(startPageNum<1)
{
startPageNum=1;
endPageNum=startPageNum+8;
}
if(endPageNum>totalPageNum)
{
endPageNum=totalPageNum;
startPageNum=endPageNum-8;
}
}
else
{
startPageNum=1;
endPageNum=totalPageNum; }
} public int getStartPageNum() {
return startPageNum;
} public void setStartPageNum(int startPageNum) {
this.startPageNum = startPageNum;
} public int getEndPageNum() {
return endPageNum;
} public void setEndPageNum(int endPageNum) {
this.endPageNum = endPageNum;
} //上一页
public int getPrePageNum() {
prePageNum=currentPageNum-1; if(prePageNum<=0)
{
prePageNum=1;
}
return prePageNum;
}
// 下一页
public int getNextPageNum() { nextPageNum=currentPageNum+1; if(nextPageNum>totalPageNum)
{
nextPageNum=totalPageNum;
}
return nextPageNum;
} public int getCurrentPageNum() {
return currentPageNum;
} public void setCurrentPageNum(int currentPageNum) {
this.currentPageNum = currentPageNum;
} public int getPageSize() {
return pageSize;
} public void setPageSize(int pageSize) {
this.pageSize = pageSize;
} public int getTotalSize() {
return totalSize;
} public void setTotalSize(int totalSize) {
this.totalSize = totalSize;
} public int getStartIndex() {
return startIndex;
} public void setStartIndex(int startIndex) {
this.startIndex = startIndex;
} public int getTotalPageNum() {
return totalPageNum;
} public void setTotalPageNum(int totalPageNum) {
this.totalPageNum = totalPageNum;
} public List getRecords() {
return records;
} public void setRecords(List records) {
this.records = records;
} public void setPrePageNum(int prePageNum) {
this.prePageNum = prePageNum;
} public void setNextPageNum(int nextPageNum) {
this.nextPageNum = nextPageNum;
} public String getUrl() {
return url;
} public void setUrl(String url) {
this.url = url;
} }

web层  简写

    //获得当前页
String num = req.getParameter("num");
if(num==null)
{
num="1";
}
//调用pageUtil工具
PageUtil page= null ;
try {
page=service.getAllUsers(num);
} catch (Exception e) {
e.printStackTrace();
}
//将数据 传入 域中 并转发到users.jsp 页面中
req.setAttribute("page", page);
req.getRequestDispatcher("/users.jsp").forward(req, resp);

service层

  userDao userDao= new userDao() ;

     public static SqlSessionFactory sqlSessionFactory = null;
//获得 工具类的信息
public PageUtil getAllUsers(String num) throws Exception{
//当前页
int currentPageNum=1 ;
// trim() 消除首尾的空格
if (num != null ) {
currentPageNum = Integer.parseInt(num);
System.out.println(currentPageNum);
}
int totalRecords =userDao.totalRecords(); PageUtil pg = new PageUtil(currentPageNum, totalRecords); List<User> users = userDao.getAllUsers(pg.getStartIndex(), pg.getPageSize()); pg.setRecords(users); return pg; }

dao

public class userDao  extends BaseDao {

    //获得所有的信息个数
public int totalRecords() throws Exception{ // 使用 jdbc 模板 作为数据的连接层
int result = 0;
Connection conn = this.getConnection();
PreparedStatement ps = null;
ResultSet rs = null;
// count(*) 返回找到的行数 count(列名) 返回一个列的数据项数 count(*) count 设置别名为 count
String sql = "select count(*) count from person";
ps = conn.prepareStatement(sql);
rs = ps.executeQuery(); if (rs.next()) {
result = rs.getInt("count");
} return result;
}
//获得 对应页的信息
public List<User> getAllUsers(int startIndex, int pageSize) throws Exception{
//使用 数组获得数据 调用DBCP模板
QueryRunner queryRunner= new QueryRunner();
String sql= "select * from person limit ?,?";
List<User> users= null ;
//获得数据
users=queryRunner.query(this.getConnection(), sql,new BeanListHandler<User>(User.class),new Object[]{startIndex,pageSize});
return users;
} }

*************************************************

使用 mybatis  pageHelper 插件 来开发

pageHelper 插件的 使用教程

这是pageHelper 的 开发者  在 GitHub 上的 使用教程

https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md

mybatis的配置信息   插入    pagehelper  插件

     <!-- 在mybatis的配置文件下 配置 pagehelper 插件    先后顺序不要错  否则会报错的  -->
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
<property name="helperDialect" value="mysql"/>
</plugin> </plugins>

mapper.xml

web层

pageHelper 插件 要比 传统的 简单的 很多   毕竟是插件嘛      它是对mybatis的四大对象    parameterHandler   resultSetHandler  statementHandler  executor   进行控制  通过反射  动态代理 实现 功能的增强    类似于 过滤器的功能

不过  值得注意的是  插件 的使用 会修改底层的设计  所以 还是尽量少用插件把

传统方式和插件方式 分别实现 分页 功能 pageHelper 插件的更多相关文章

  1. SpringBoot集成Mybatis并具有分页功能PageHelper

    SpringBoot集成Mybatis并具有分页功能PageHelper   环境:IDEA编译工具   第一步:生成测试的数据库表和数据   SET FOREIGN_KEY_CHECKS=0;   ...

  2. 利用Bootstrap Paginator插件和KnockoutJS完成分页功能

    在最近一个项目中,需要结合一堆条件查询并对查询的结果数据完成一个简单分页功能,可是做着做着,自己的思路越来越模糊,做到心态崩溃!!! 哈哈,特此花点时间重新总结,并从最简单的分页,然后向多条件查询分页 ...

  3. spring和mybatis集成,自动生成model、mapper,增加mybatis分页功能

    软件简介 Spring是一个流行的控制反转(IoC)和面向切面(AOP)的容器框架,在java webapp开发中使用广泛.http://projects.spring.io/spring-frame ...

  4. C#不用union,而是有更好的方式实现 .net自定义错误页面实现 .net自定义错误页面实现升级篇 .net捕捉全局未处理异常的3种方式 一款很不错的FLASH时种插件 关于c#中委托使用小结 WEB网站常见受攻击方式及解决办法 判断URL是否存在 提升高并发量服务器性能解决思路

    C#不用union,而是有更好的方式实现   用过C/C++的人都知道有个union,特别好用,似乎char数组到short,int,float等的转换无所不能,也确实是能,并且用起来十分方便.那C# ...

  5. Maven插件方式使用Mybatis Generator

    Mybatis Generator Mybatis Generator简称MBG,可以根据数据库自动生成实体类.单表查询接口及其映射xml文件(也可以选择以注解方式生成). 下面介绍一下以maven插 ...

  6. 如何实现Windows Phone代码与Unity相互通信(插件方式)

    原地址:http://www.cnblogs.com/petto/p/3915943.html 一些废话 原文地址: http://imwper.com/unity/petto/%E5%A6%82%E ...

  7. Eclipse扩展安装插件方式

    Eclipse安装插件经常使用的是直接安装的方式,就是将插件中包含的plugins和features文件夹中的内容直接复制到了Eclipse的plugins和features文件夹内,这样很容易导致插 ...

  8. GDAL使用插件方式编译HDF4、HDF5以及NetCDF的bug修改

    GDAL库中提供了很方便的插件机制来扩展支持的数据格式,比如HDF4.HDF5.NetCDF.FileGDB.Postgre.Oralce等等.都可以通过插件的方式来使得GDAL支持相应的格式.最近将 ...

  9. Django【设计】可插拔的插件方式实现

    需求: 在CMDB系统中,我们需要对资产进行采集和资产入库,包括serverBasic.disk.memory.nic信息等,客户端需要采集这些硬件的信息,服务端则负责资产入库,但是需要采集的硬件并不 ...

随机推荐

  1. 第十九节: 结合【表达式目录树】来封装EF的BaseDal层的方法

    一. 简介 该章节,可以说是一个简单轻松的章节,只要你对Expression表达式树.EF的基本使用.泛型有所了解,那么本章节实质上就是一个非常简单的封装章节,便于我们快捷开发. PS:在该章节对于E ...

  2. CSS难点 为什么height设置100%会失效,分栏目等高布局(高度自适用布局)的实现方案

    前言 相信在平时写CSS的时候大家都或多或少遇见过设置了height为百分比的时候发现不起作用.今天我们就来一探究竟 原因:父元素未设置具体高度,子元素设置height:100%是无效的. 现象以及方 ...

  3. Codeforces Round #545 (Div. 2) C. Skyscrapers 离散化+贪心

    题目链接 给你一个n∗m的矩阵res,让你输出一个n∗m的矩阵a,这个矩阵满足:给你一个n*m的矩阵res,让你输出一个n*m的矩阵a,这个矩阵满足:给你一个n∗m的矩阵res,让你输出一个n∗m的矩 ...

  4. sql server 中用于排名的三个函数 row_number() ,RANK() 和 DENSE_RANK()

    row_number()  ,RANK() 和  DENSE_RANK()  三个配合over()  使用排名 只是只是计算方式不一样,语法基本一样 语法: ROW_NUMBER() OVER (OR ...

  5. Fast R-CNN(理解)

    0 - 背景 经典的R-CNN存在以下几个问题: 训练分多步骤(先在分类数据集上预训练,再进行fine-tune训练,然后再针对每个类别都训练一个线性SVM分类器,最后再用regressors对bou ...

  6. CentOS安装Supervisor

    什么是Supervisor Supervisor是一个进程控制系统. 它是一个C/S系统,服务端是supervisord进程,控制端使用supervisorctl来进行控制启动进程.同时它也提供了一个 ...

  7. const与#define相比有什么不同?

    C++语言可以用const定义常量,也可以用#define定义常量,但是前者比后者有更多的优点:● const常量有数据类型,而宏常量没有数据类型.编译器可以对前者进行类型安全检查,而对后者只进行字符 ...

  8. C# .Net String字符串效率提高-字符串拼接

    字符串操作是编程中非常频繁的操作,特别是在拼接字符串的时候.下面来说说字符串拼接的效率提升. 1. 减少装箱 值类型与引用类型之间的转换存在装箱与拆箱操作:将值类型转换成引用类型的操作叫装箱,将引用类 ...

  9. openKM部署二次开发,eclipse环境

    1.下载openKM_install_forwin安装包,配置jdk环境,start openKM,访问localhost\OpenKM,用户:okmAdmin 密码:admin.查看是否启动成功.安 ...

  10. cookie报错

    错误: java.lang.IllegalArgumentException: An invalid character [32] was present in the Cookie value 原因 ...