首页 技术 正文
技术 2022年11月6日
0 收藏 428 点赞 809 浏览 3122 个字

首先封装一个分页类

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();
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,084
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,559
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,408
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,181
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,818
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,901