今天周一,趁工作轻松,自己就写了一个基于MySQl数据库的分页查询,做分页,最主要的是以下几点:
一:写sql语句:比如查询某张数据表的数据,sql语句为:select * from table limit 0,10
焦点就是limit这个限制条件,它的功能是:从0开始查询10条数据,表示你要在你的显示页面上显示10条数据,就是说你数据库表里面有15条,那只能显示10条,剩余5条数据
只能在下一页中显示。
同时需要查询数据库表中的数据总数:select count(*) from table , 用于获取数据的总页数。详细的介绍在代码中有解析。
二:要有一个类用来专门处理分页功能:Pages.java;这个不多说,直接上代码,在代码中有详细的注释:
package com.utis.util; import java.util.List; public class Page<T> {
private int pageSize =10; //每页显示条数
private int totalCount; //总条数
private int start; //开始条数
private int pageNo;//当前页
private int totalPages; //总页数
private List<T> pageList;//数据 public Page(int totalCount){
this.totalCount = totalCount;
} /**
* ��ȡ��ǰ获取��下一条
*/
public int getCurrentPageNo(){
return start / pageSize + 1;
}
/**
* �Ƿ�����是否有下一条
* @return
*/
public boolean getHasNextPage(){
return getCurrentPageNo() < totalPages;
}
/**
* �Ƿ�����当前页是否大于1
* @return
*/
public boolean getHasPavPage(){
return getCurrentPageNo() > 1;
}
/**
* ��ȡ��获取中页数��
* @return
*/
public int getTotalPages() {
totalPages = totalCount / pageSize; if(totalCount % pageSize != 0){
totalPages++;
} return totalPages;
}
/**
* ��õ�设置当前页����ʼ��的开始条数
* @param pageNo ��ǰ页数��
* @return
*/
public int getStart(int pageNo){ if(pageNo < 1){
pageNo = 1;
}
else if(getTotalPages()>0&&pageNo > getTotalPages()){
pageNo = getTotalPages();
} start = (pageNo-1) * pageSize;
return start;
} //get and set
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 void setStart(int start) {
this.start = start;
}
public List<T> getPageList() {
return pageList;
}
public void setPageList(List<T> pageList) {
this.pageList = pageList;
}
public void setTotalPages(int totalPages) {
this.totalPages = totalPages;
} public int getPageNo() {
return pageNo;
} public void setPageNo(int pageNo) {
this.pageNo = pageNo;
} }
三:这时候就要做dao,service层的逻辑了,不过也挺简单的,概括来说,将调用dao查询出来的数据,在 service层将其存储到Pages<T>类中的pageList集合里面,并且还要把pageNo当前 页 setPageNo(pageNo)中,为嘛要这样呢,一将数据交给page类来分页处理,二在显示页面有首页,上一页,下一页,尾页吧,这就是原因啦, 要用来获取参数pageNo用的,别的也 不多说,先上代码看看:
/**
* 查询未借阅的图书
*/
public Page<Book> findBook(int pageNo){
Page<Book> pages = new Page<Book>(findBookCount());
pages.setPageNo(pageNo);
pages.setPageList(bookDao.findBook(pages.getStart(pageNo), pages.getPageSize()));
return pages;
}
/**
* 查询图书总数
*/
public Integer findBookCount(){
return bookDao.findBookCount();
}
四:显示页:该页面只是简单地写了一下,其中bug还是挺多的,但具体怎么修改还需要结合项目来操作
<form action="<%=basePath%>book/findBook" method="post">
<a href="<%=basePath%>book/findBook?pageNo=1">【首页】</a>
<a href="<%=basePath%>book/findBook?pageNo=${booklist.pageNo-1}">【上一页】</a>
<c:forEach begin="1" var="i" end="${booklist.totalPages}">
<a href="<%=basePath%>book/findBook?pageNo=${i }">${i }</a>
</c:forEach>
<a href="<%=basePath%>book/findBook?pageNo=${booklist.pageNo+1}">【下一页】</a>
<a href="<%=basePath%>book/findBook?pageNo=${booklist.totalPages }">【尾页】</a>
<input type="text" size="1" name="pageNo" value="${booklist.pageNo}"/>
<input type="submit" value="GO" size="1"/>
当前第${booklist.pageNo}页/共${booklist.totalPages}页
</form>
以上是我自己做的一个练习,还是有很多不足之处,其实分页方法有 很多种,我做的这种是物理分页,还有一种分页叫逻辑分页,这种分页方式依靠的是对结果集的算法来分页,因此通常被称为“逻辑分页”,该分页其实是将数据库的压力交给了应用端,其实这两种分页查询效率差别不大,但是我推荐使用物理分页,不能因为提高一些速度而将数据库的压力交给了应用端而使用逻辑分页,因为物理分页在其他的性能上足以弥补了少许的劣势。