当数据库中数据条数过多时,一个页面就不能显示,这是要设置分页查询,首先要使用的是数据库sql语句的limit条件实现分组查询
sql语句大概形式为:
  select * from table limit 开始索引,显示条数
  用该语句就会实现分块查询,并且每页显示固定条数。

  (由于limit是mysql特有的,如果是Oracle数据库的话就需要通过rownum来限制比如:select * from table where rownum >=开始索引。如果是sql sever数据库的话可以用到top关键字,如取m到n条数据:select top (n-m+1) id from table where id not in (select top m-1 id from table))
首先要实现后台分页,我们需要知道它有多少页,每页有多少行,这就需要知道一共多少行,调用sql语句时还需要知道每一页的开始索引,开始索引是根据当前页数算出来的,所以还需要知道当前页数,查询后会返回一个列表存储当前页数据。将这些属性及获取设置的方法封装成一个类就有了下面的page类:

 1 public class Page<T> {
 2     private List<T> data;//数据列表
 3     private int pagenum;//当前页数
 4     private int pagesize;//当前页显示条数
 5     private int rows;//总行数
 6     public Page(int rows,int pagenum, int pagesize) {
 7         super();
 8         data=new ArrayList<>();
 9         this.rows=rows;
10         this.setPagesize(pagesize);
11         this.setPagenum(pagenum);        
12     }
13     public Page() {
14         super();
15     }
16     public int getPagenum() {
17         return pagenum;
18     }
19     public void setPagenum(int pagenum) {
20         if(pagenum>getTotalpage())
21         {
22             this.pagenum=getTotalpage();
23         }
24         else {
25             this.pagenum = pagenum;
26         }    
27         if(pagenum<1)
28         {
29             this.pagenum=1;
30         }
31     }
32     public int getPagesize() {
33         return pagesize;
34     }
35     public void setPagesize(int pagesize) {
36         this.pagesize = pagesize;
37     }
38     public int getTotalpage() {
39         //计算总页数
40         if(rows%pagesize==0)
41         {
42             return rows/pagesize;
43         }
44         else {
45             return rows/pagesize+1;
46         }        
47     }
48     public int getRows() {
49         return rows;
50     }
51     public void setRows(int rows) {
52         this.rows = rows;
53     }
54     public int getIndexnum() {
55         //获取索引值
56         return pagesize*(pagenum-1);
57     }
58     public List<T> getData() {
59         return data;
60     }
61     public void setData(List<T> data) {
62         this.data = data;
63     }
64 }
Page类

相关文章: