首先封装一个分页类

public class Page<T> {
/**
* 当前页号
*/
private int pageNumber;
/**
* 总条数
*/
private int totalCount;
/**
* 总页数
*/
private int totalPage;
/**
* 每页显示的数量
*/
private int pageSize;
/**
* 当前页的数据
*/
private List<T> item; /**
* 当前起始行号
* @return
*/
private int from; public Page(){} public Page(int pageSize,int totalCount,String pageNumber) {
setPageSize(pageSize);
setTotalCount(totalCount);
setPageNumber(pageNumber);
} public int getPageNumber() {
return pageNumber;
}
public void setPageNumber(String pageNumber) { if(StringUtil.isNumber(pageNumber)){
int tempNumber = Integer.parseInt(pageNumber);
if(tempNumber < 1){
tempNumber = 1;
}else if(tempNumber > getTotalPage()){
tempNumber = getTotalPage();
} this.pageNumber = tempNumber; }else{
this.pageNumber = 1;
} }
public int getTotalCount() {
return totalCount;
}
public void setTotalCount(int totalCount) {
this.totalCount = totalCount; this.totalPage = totalCount / getPageSize();
if(totalCount % getPageSize() != 0) {
this.totalPage++;
} }
public int getTotalPage() {
return totalPage;
}
/*public void setTotalPage(int totalPage) {
this.totalPage = totalPage;
}*/
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public List<T> getItem() {
return item;
}
public void setItem(List<T> item) {
this.item = item;
}
public int getFrom() {
return (getPageNumber() - 1) * getPageSize();
}
public void setForm(int from) {
this.from = from;
} public List<Integer> getSlider(){ int startPageNumber = getPageNumber() - 2;
int endPageNumber = getPageNumber() + 2; if(startPageNumber <= 0){
endPageNumber -= startPageNumber - 1;
startPageNumber = 1;
} if(endPageNumber > getTotalPage()){
int temp = getTotalPage() - endPageNumber;
endPageNumber = getTotalPage();
startPageNumber = startPageNumber + temp;
if(startPageNumber < 1){
startPageNumber = 1;
}
} List<Integer> result = new ArrayList<Integer>(); for(int i = startPageNumber;i <= endPageNumber;i++){
result.add(i);
} return result;
} }

controller中

Page<Active> page = new ActiveService().findByProjectid(projectid,pageNo);

service中

public Page<Active> findByProjectid(String projectid, String pageNo) {

        return activeDao.findAllByidAndPageNo(Long.valueOf(projectid),pageNo);
}

dao中

public Page<Active> findAllByidAndPageNo(Long projectid, String pageNo) {

        String sql = "SELECT * FROM active,account WHERE active.accountid = account.id AND projectid = ? order by active.id desc limit ?,?";

        Page<Active> page = new Page<Active>(5, findActiveCountByprojectid(projectid), pageNo);
//因为返回的page中的item里是没有account信息的,但是在home.jsp中需要显示account的头像和姓名,所以要重写这个rowmapper
List<Active> list = db.queryForList(sql, new RowMapper<Active>(){ @Override
public Active mapRow(ResultSet rs) throws SQLException {
Active active = new Active();
active.setAccountid(rs.getLong("accountid"));
active.setContext(rs.getString("context"));
active.setCreatetime(rs.getTimestamp("createtime"));
active.setId(rs.getLong("id"));
active.setProjectid(rs.getLong("projectid"));
active.setType(rs.getString("type")); Account account = new Account();
account.setId(rs.getLong("accountId"));
account.setUsername(rs.getString("username"));
account.setPic(rs.getString("pic")); active.setAccount(account);
return active;
} }, projectid,page.getFrom(),page.getPageSize()); page.setItem(list); return page;
}
private int findActiveCountByprojectid(Long projectid) {
String sql = "select count(*) from active where projectid = ?";
return db.queryForCount(sql, projectid).intValue();
}

page分页的更多相关文章

  1. page分页问题,根据页码获取对应页面的数据,接口调用

    添加一个log.js文件,进行接口调用. import axios from '@/libs/api.request' const MODULE_URL = '/log'; export const ...

  2. layui -page 分页类

    <?phpnamespace page; // +---------------------------------------------------------------------- / ...

  3. 封装page分页类

    类: <?php //分页工具类 class Page{ /*         * 获取分页字符串         * @param1 string $uri,分页要请求的脚本url       ...

  4. page分页类

    <?php /** file: Page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 private $lis ...

  5. java Page分页显示

    //entity层实体类 import java.util.List; //分页展示 //相关属性:当前页,页大小(每页显示的条数),总页数,总条数,数据 //select * from t_user ...

  6. jQuery.page 分页控件

    分享一下自己在项目中引用的Jquery分页控件 index.html内容 <!DOCTYPE html> <html lang="zh-cn" xmlns=&qu ...

  7. page 分页

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...

  8. MVC Page分页控件

    MVCPage帮助类 控制器代码 public ActionResult Article(int? page) { //Session["ArticleClass"] = cont ...

  9. JPA+Postgresql+Spring Data Page分页失败

    按照示例进行如下代码编写 Repository Page<DeviceEntity> findByTenantId(int tenantId, Pageable pageable); se ...

随机推荐

  1. JS闭包经典例题

    上一篇文章谈论了闭包的概念和一些应用,并给出一个例题,这篇文章就此道例题进行讨论. function fun(n,o) { console.log(o); return { fun:function( ...

  2. 传统web和mvc的区别

  3. sql表连接的几种方式

    这里有两张表TableA和TableB,分别是姓名表和年龄表,用于我们例子的测试数据 TableA id name 1 t1 2 t2 4 t4 TableB id age 1 18 2 20 3 1 ...

  4. 小猪猪C++笔记基础篇(五)表达式、语句

    小猪猪C++笔记基础篇(五) 关键词:表达式.语句 本章的内容比较简单,基本上没有什么理解上的困难,都是知识上的问题.先开始想要不要写呢,本来是不准备写的,但是既然读了书就要做笔记,还是写一写,毕竟还 ...

  5. BZOJ 1211: [HNOI2004]树的计数( 组合数学 )

    知道prufer序列就能写...就是求个可重集的排列...先判掉奇怪的情况, 然后答案是(N-2)!/π(d[i]-1)! -------------------------------------- ...

  6. pwntools安装使用方法

    pwntools是一个CTF框架和漏洞利用开发库,用Python开发,由rapid设计,旨在让使用者简单快速的编写exploit. pwntools对Ubuntu 12.04和14.04的支持最好,但 ...

  7. Python BeautifulSoup中文乱码问题的2种解决方法

    解决方法一: 使用python的BeautifulSoup来抓取网页然后输出网页标题,但是输出的总是乱码,找了好久找到解决办法,下面分享给大家首先是代码 from bs4 import Beautif ...

  8. 全新安装mysql最新版本

    写在前面: 下面写的东西只是最近安装的一个说明,是在系统中没存在mysql的情况下安装的,后期会根据官方文档写一个详细有价值的文档 安装原理:利用mysql官方的mysql_apt-repositor ...

  9. QTP 9.2 下载&破解

    版本不同 但是破解总是这个 crack文件下载 http://ishare.iask.sina.com.cn/f/13802744.html   QTP9.2 下载地址 http://www.duot ...

  10. yoeman构建Asp.net core项目并且实现分层

    在Mac上开发使用yoeman构建Asp.net core项目并且实现分层引用 1.Yoeman? yoeman是一个自动化脚手架工具.它提供很多generator,generator相当于Visua ...