当要显示数据量足够大的时候,我们往往采用分页显示的处理办法。
———————————–分页有真分页和假分页—————————————
真分页:
确定要显示的数量和内容,然后每次都去数据库取出该少量数据,优点是数据量小,缺点是访问数据库频繁。
假分页:
从数据库中取出所有的数据,然后分页在界面上显示。访问一次数据库,但由于选择的数据量比较大,所以第一次花费时间比较长,但之后每一页的显示都是直接、快速的,避免对数据库的多次访问。
假分页,不是真正的在数据库里进行过滤,而是从数据库查询之后,取得全部结果,在展现的时候做些手脚。
真假分页辨别
看查询的SQL语句,如果一次取全部数据,就是假分页,如果SQL语句是取每页的数据条数,就是真分页
假分页
http://blog.csdn.net/ghsau/article/details/7243540
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
public class Pager<T> {
/**
* 每页显示条数
*/
private int pageSize;
/**
* 原集合
*/
private List<T> data;
private Pager(List<T> data, int pageSize) {
if (data == null || data.isEmpty()) {
throw new IllegalArgumentException("data must be not empty!");
}
this.data = data;
this.pageSize = pageSize;
}
/**
* 创建分页器
*
* @param data 需要分页的数据
* @param pageSize 每页显示条数
* @param <T> 业务对象
* @return 分页器
*/
public static <T> Pager<T> create(List<T> data, int pageSize) {
return new Pager<>(data, pageSize);
}
/**
* 得到分页后的数据
*
* @param pageNum 页码
* @return 分页后结果
*/
public List<T> getPagedList(int pageNum) {
int fromIndex = (pageNum - 1) * pageSize;
if (fromIndex >= data.size()) {
return Collections.emptyList();
}
int toIndex = pageNum * pageSize;
if (toIndex >= data.size()) {
toIndex = data.size();
}
return data.subList(fromIndex, toIndex);
}
public int getPageSize() {
return pageSize;
}
public List<T> getData() {
return data;
}
public static void main(String[] args) {
Integer[] array = {
1, 2, 3, 4, 5,