java web 分页技术详解及代码
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
java web 分页技术详解及代码
关于在java web上实现分页技术,方式实际上有很多,也各有个的特点,此处我只写些我的认识。java web分页无外乎两种,一种是直接取出来,放到一个集合里,通过传begin 和end 参数控制分页,还有一种就是把分页工作交给数据库,让数据库读取需要的begin~end 之间的数据。
我们这里,先看从数据库中读取的情况
操作数据库就需要tsql语句,mssqlserver2005新推出了一个row_number()很好用,还有就是mysql的limit也非常好使。
mssqlserver2005的如下:
select * from (select row_number() over (order by ename) as rn, f.* from emp f) b
where b.rn between 6 and 10;
mysql的:
select * from emp limit 5,5
mysql的应注意,使用limit时,表中必须用主键,还有limit后的两个参数分别代表(标识位,长度),标识位从0开始
现在开始一步步完成,首先完成model模块,建立pagebean
import java.util.*;
public class PageBean {
private Collection objs;//从数据库中读的集合
private int totalCount;//总的条数
private int pageNo;//当前的页数
private int pageCount;//每页的条数
public int getPageCount() {
return pageCount;
}
public void setPageCount(int pageCount) {
this.pageCount = pageCount;
}
public void setPageNo(int pageNo) {
this.pageNo = pageNo;
}
public int getTotalPage(){
if(totalCount % pageCount == 0){
return totalCount/pageCount;
} else {
return totalCount/pageCount + 1;
}
}
//多写一个判断下一页的方法
public boolean isNext(){
return pageNo < getTotalPage();
}
//上一页的方法
public boolean isPrevious(){
return pageNo > 1;
}
public Collection getObjs() {
return objs;
}
public void setObjs(Collection objs) {
this.objs = objs;
}
public int getPageNo() {
return pageNo;
}
public int getTotalCount() {
return totalCount;
}
public void setTotalCount(int totalCount) {
this.totalCount = totalCount;
}
public PageBean(Collection objs, int totalCount, int pageNo, int pageCount) {
this.objs = objs;
this.totalCount = totalCount;
this.pageNo = pageNo;
this.pageCount = pageCount;
}
}
之后开始实现biz模块
我们写一个具体分页的逻辑
import java.util.*;
import java.sql.*;
public class EmpBiz {
public EmpBiz() {
}
//具体实现分页的方法,传递两个参数,一个第几页,一个每页的数量
public PageBean listEmps(int pageNo, int pageCount){
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
ArrayList emps = new ArrayList();
//次数我使用mssqlserver的方式,所以计算前后两个范围,用a,b表示
int a = pageNo* pageCount;
int b = (pageNo-1)* pageCount;
try {
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
con=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;databaseName=Master;","sa" ,"sa");
stmt = con.createStatement();
rs = stmt.executeQuery("select * from (select row_number() over (order by ename) as rn, f.* from emp f) b
where b.rn between "+a+" and "+b);
while(rs.next()){
Employee e = new Employee();
e.setEmpno(rs.getInt("empno"));