1.实体层(entity,pojo,domain)

package com.entity;

import java.io.Serializable;

      private int totalCount;      //总记录数

      private int totalPageCount;  //总页数

      private int startPos;        //开始位置,从0开始

      private boolean hasFrist;    //是否有首页

      private boolean hasPre;      //是否有前一页

      private boolean hasNext;     //是否有后一页

      private boolean hasLast;     //是否有尾页

      /**
* 通过构造函数,传入总记录数和当前页
* @param pageNow
* @param totalCount
*/
public CountPage(int pageNow, int totalCount) {
super();
this.pageNow = pageNow;
this.totalCount = totalCount;
}
//获取总页数
public int getTotalPageCount() {
totalPageCount=getTotalCount()/getPageSize();
return (totalCount/pageSize==1) ? totalPageCount:totalPageCount+1;
} public void setTotalPageCount(int totalPageCount) {
this.totalPageCount = totalPageCount;
} public int getPageNow() {
return pageNow;
} public void setPageNow(int pageNow) {
this.pageNow = pageNow;
} public int getPageSize() {
return pageSize;
} public void setPageSize(int pageSize) {
this.pageSize = pageSize;
} public int getTotalCount() {
return totalCount;
} public void setTotalCount(int totalCount) {
this.totalCount = totalCount;
}
//取得选择记录的初始位置
public int getStartPos() {
return (pageNow-1)*pageSize;
} public void setStartPos(int startPos) {
this.startPos = startPos;
}
//判断是否有第一页
public boolean isHasFrist() {
return (pageNow==1) ? false:true;
} public void setHasFrist(boolean hasFrist) {
this.hasFrist = hasFrist;
}
//如果有首页就有前一页
public boolean isHasPre() {
return isHasFrist() ? true:false;
} public void setHasPre(boolean hasPre) {
this.hasPre = hasPre;
}
//如果有尾页就有下一页
public boolean isHasNext() {
return isHasNext() ? true:false;
} public void setHasNext(boolean hasNext) {
this.hasNext = hasNext;
}
//判断是否有尾页
public boolean isHasLast() {
return (pageNow==getTotalCount()) ? false:true;
} public void setHasLast(boolean hasLast) {
this.hasLast = hasLast;
} }

2.DAO层

package com.dao;

import java.util.List;

import com.entity.MyAccount;

public interface MyAccountMapper {

    /*  查询所有   传值(当前页,每页显示多少条数据) */
List<MyAccount> findAll(Integer pageNow,Integer pageSize);
/* 查询总数 */
Integer myAccountCount(); }

3.xxxmapper.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="com.dao.MyAccountMapper" >
<!-- 查询所有 并用 limit 进行 分页 -->
<select id="findAll" resultType="com.entity.MyAccount">
select * from account limit #{0},#{1}
</select>
<!-- 查询总数 -->
<select id="accountCount" resultType="Integer">
select COUNT(*) from account
</select>
</mapper>

4.服务层(service)

package com.service;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import com.dao.MyAccountMapper;
import com.entity.MyAccount; @Transactional
@Service
public class AccountService { @Autowired
MyAccountMapper accountMapper = null; /**
* 查询 所有 账户
*/
public List<MyAccount> findAll(Integer pageNow,Integer pageSize){
System.out.println("业务查询 >>> 查询我的所有账户");
List<MyAccount> list = accountMapper.findAll(pageNow, pageSize);
System.out.println("查询到的结果是 >>> " + list.toString());
return list;
} /**
* 查询 总页数
*/
public Integer myAccountCount(){
System.out.println("业务查询 >>> 查询所有账户数量");
return accountMapper.myAccountCount();
}
}

5.控制层(Controller)

package com.web;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession; import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping; import com.entity.CountPage;
import com.entity.MyAccount;
import com.service.AccountService; @Controller
public class AccountController { @Resource
AccountService accountService = null; /**
* 查询所有账户
*/
@RequestMapping(value = "/account")
public String findAll(Model model,HttpServletRequest request){ //获取当前页数
String pageNow=request.getParameter("pageNow");
//获取总页数
int totalCount=(int)accountService.myAccountCount();
//初始化 CountPage 对象 page
CountPage page=null;
//new 一个 集合 把数据 放进集合里
List<MyAccount> list=new ArrayList<MyAccount>();
if (pageNow!=null) {
page=new CountPage(Integer.parseInt(pageNow), totalCount);
list=this.accountService.findAll(page.getStartPos(),page.getPageSize());
}else {
page=new CountPage(1, totalCount);
list=this.accountService.findAll(page.getStartPos(),page.getPageSize());
}
//把数据放到 model 中并转发到 jsp 页面
model.addAttribute("list", list);
model.addAttribute("page", page);
return "myaccount";
}
}

6.页面代码(JSP)

<div class="pager">
<font size="2">共 ${page.totalPageCount} 页</font> <font size="2">第
${page.pageNow} 页</font> <a href="account?pageNow=1">首页</a>
<c:choose>
<c:when test="${page.pageNow - 1 > 0}">
<a href="account?pageNow=${page.pageNow - 1}">上一页</a>
</c:when>
<c:when test="${page.pageNow - 1 <= 0}">
<a href="account?pageNow=1">上一页</a>
</c:when>
</c:choose>
<c:choose>
<c:when test="${page.totalPageCount==0}">
<a href="account?pageNow=${page.pageNow}">下一页</a>
</c:when>
<c:when test="${page.pageNow + 1 < page.totalPageCount}">
<a href="account?pageNow=${page.pageNow + 1}">下一页</a>
</c:when>
<c:when test="${page.pageNow + 1 >= page.totalPageCount}">
<a href="account?pageNow=${page.totalPageCount}">下一页</a>
</c:when>
</c:choose>
<c:choose>
<c:when test="${page.totalPageCount==0}">
<a href="account?pageNow=${page.pageNow}">尾页</a>
</c:when>
<c:otherwise>
<a href="account?pageNow=${page.totalPageCount}">尾页</a>
</c:otherwise>
</c:choose>
</div>

:其中 <a href="account?pageNow=1">首页</a>  ( account  是 控制层(Controller) @RequestMapping(value = "/account") 的值)

记一次 SSM 分页的更多相关文章

  1. 记一次SSM项目小结(一)

    记一次SSM项目小结(一) ssm框架 环境配置 服务器配置 解决方法  拦截器重定向到localhost nginx和tomcat中session失效 mybatis的xml文件不生效 数据库用户创 ...

  2. 基于Mysql数据库的SSM分页查询

    前言: Hello,本Y又来了,"分页"在我们使用软件的过程中是一个很常见的场景,比如博客园对于每个博主的博客都进行了分页展示.可以简单清晰的展示数据,防止一下子将过多的数据展现给 ...

  3. ssm分页

    pom.xml配置文件中增加相关的插件. <dependency> <groupId>com.github.pagehelper</groupId> <art ...

  4. 记一次Layui分页

    <link rel="stylesheet" href="/layui/css/layui.css"> <div class="ro ...

  5. mysq带条件的分页查询数据结果错误

    记一次mysql分页条件查询的结果出错: 以一张用户表为例,首先我们看表中的所有数据,注意红色框住的部分: 我们使用不带条件的分页查询来查询,数据显示是OK的: SELECT id,login_nam ...

  6. SQLServer分页查询笔记

    学习SqlServer到现在快两年了吧,分页查询总是忘了看笔记,看了又忘.之前用的分页都是row_number函数的方式,背不住...直到今天,看到别人写的另一种分页写法,看似比row_number简 ...

  7. 8.bash编辑命令行

    8.编辑命令行本章介绍 GNU 命令行编辑界面的基本功能.命令行编辑是 Readline 库提供的:这个库被几个不同的程序共用,Bash 是其中一个.使用交互式的 shell 时,默认已经打开了命令行 ...

  8. 基于SSM的分页

    现在基本每一个项目都有用到分页,SSM也是当前企业用到的比较频繁的框架,这里我就总结一下基于SSM的分页: 一.首先我们要准备一个分页的工具类 /** * 分页 */ public class Pag ...

  9. 基于SSM框架的简易的分页功能——包含maven项目的搭建

    新人第一次发帖,有什么不对的地方请多多指教~~ 分页这个功能经常会被使用到,我之前学习的时候找了很多资源,可都看不懂(笨死算了),最后还是在朋友帮助下做出了这个分页.我现在把我所能想到的知识 做了一个 ...

随机推荐

  1. 给GRUB添加新的项目

    安装了win10,然后又安装了manjaro,最后又安装了Ubuntu.开机默认就是进入的Ubuntu的grub,然而我比较喜欢manjaro的grub主题.在bios中设置manjaro的引导为默认 ...

  2. Ubuntu 远程 Jupyter 配置

    Ubuntu 远程 Jupyter 配置 每次上课都要重新部署环境,最近看到阿里云的大学生优惠活动,就着手了一台云服务器,于是就把环境部署在上面了. 环境:阿里云 Ubuntu 16.04 64位 新 ...

  3. 【SSL Certificates】什么是数字证书(Certificates)?

    本文涉及的相关问题,如果你的问题或需求有与下面所述相似之处,请阅读本文 ssl certificate 什么是ssl certificates? SSL Certificates 是一种使用数字加密技 ...

  4. vue+vux页面滚动定位(支持上下滑动)

    接上篇文章:https://www.cnblogs.com/ligulalei/p/10622778.html在上篇文章中实现了通过使用scrollIntoView()在使用vux的移动端实现了点击锚 ...

  5. 解决一次git问题

    由于特殊原因,工作中不能使用sourcetree,今天遇到了一个问题记录一下解决办法,后续还是得好好去廖雪峰大神那里学习一下git的命令行操作呀 You have not concluded your ...

  6. 【Mac】【问题】

    [一]export: `PATH;': not a valid identifier 可能是环境变量配的有问题 一般是~/.bash_profile 多了空格或是多了$符号之类的

  7. Linux之磁盘分区

    一.基础知识 1.磁盘分区 磁盘的分区主要分为基本分区(primary partion)和扩充分区(extension partion)两种,基本分区和扩充分区的数目之和不能大于四个.且基本分区可以马 ...

  8. y

    switch(update_state) { : switch(num){ : window.progressn=num $('#h_progress_bar .ui-progress').anima ...

  9. Python第三方库的安装 --Python3

    1.使用安装包管理工具安装:easy_install .pip/pip3 easy_install:easy_install是由PEAK(Python Enterprise Application K ...

  10. LeetCode--034--在排序数组中查找元素的第一个和最后一个位置(java)

    给定一个按照升序排列的整数数组 nums,和一个目标值 target.找出给定目标值在数组中的开始位置和结束位置. 你的算法时间复杂度必须是 O(log n) 级别. 如果数组中不存在目标值,返回 [ ...