程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java分頁之假分頁

java分頁之假分頁

編輯:關於JAVA
 

假分頁,顧名思義,不是真正的在數據庫裡進行過濾,而是從數據庫查詢之後,取得全部結果,在展現的時候做些手腳。

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

/**
* @author shuang.gao Date: 2016/1/28 Time: 12:26
*/
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, 6, 7, 8, 9, 10, 11, 12};
List<Integer> list = Arrays.asList(array);

Pager<Integer> pager = Pager.create(list, 10);

List<Integer> page1 = pager.getPagedList(1);
System.out.println(page1);

List<Integer> page2 = pager.getPagedList(2);
System.out.println(page2);

List<Integer> page3 = pager.getPagedList(3);
System.out.println(page3);
}
}

 

這是一個簡單的分頁器,原理很簡單,將從數據庫查詢的數據,傳入到分頁器裡,返回的是分好頁的集合。

優點是兼容所有JDBC數據庫,缺點是這種方法不適用於大批量數據。

 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved