java分頁(yè)之假分頁(yè)實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)器
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> { /** * 每頁(yè)顯示條數(shù) */ 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; } /** * 創(chuàng)建分頁(yè)器 * * @param data 需要分頁(yè)的數(shù)據(jù) * @param pageSize 每頁(yè)顯示條數(shù) * @param <T> 業(yè)務(wù)對(duì)象 * @return 分頁(yè)器 */ public static <T> Pager<T> create(List<T> data, int pageSize) { return new Pager<>(data, pageSize); } /** * 得到分頁(yè)后的數(shù)據(jù) * * @param pageNum 頁(yè)碼 * @return 分頁(yè)后結(jié)果 */ 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); } }
假分頁(yè),顧名思義,不是真正的在數(shù)據(jù)庫(kù)里進(jìn)行過(guò)濾,而是從數(shù)據(jù)庫(kù)查詢之后,取得全部結(jié)果,在展現(xiàn)的時(shí)候做些手腳。
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> {
/**
* 每頁(yè)顯示條數(shù)
*/
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;
}
/**
* 創(chuàng)建分頁(yè)器
*
* @param data 需要分頁(yè)的數(shù)據(jù)
* @param pageSize 每頁(yè)顯示條數(shù)
* @param <T> 業(yè)務(wù)對(duì)象
* @return 分頁(yè)器
*/
public static <T> Pager<T> create(List<T> data, int pageSize) {
return new Pager<>(data, pageSize);
}
/**
* 得到分頁(yè)后的數(shù)據(jù)
*
* @param pageNum 頁(yè)碼
* @return 分頁(yè)后結(jié)果
*/
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);
}
}
這是一個(gè)簡(jiǎn)單的分頁(yè)器,原理很簡(jiǎn)單,將從數(shù)據(jù)庫(kù)查詢的數(shù)據(jù),傳入到分頁(yè)器里,返回的是分好頁(yè)的集合。
優(yōu)點(diǎn)是兼容所有JDBC數(shù)據(jù)庫(kù),缺點(diǎn)是這種方法不適用于大批量數(shù)據(jù)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- java ssm框架實(shí)現(xiàn)分頁(yè)功能的示例代碼(oracle)
- 詳述 DB2 分頁(yè)查詢及 Java 實(shí)現(xiàn)的示例
- Java分頁(yè)查詢--分頁(yè)顯示(實(shí)例講解)
- Java實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)功能
- datatables 帶查詢條件java服務(wù)端分頁(yè)處理實(shí)例
- java實(shí)現(xiàn)cassandra高級(jí)操作之分頁(yè)實(shí)例(有項(xiàng)目具體需求)
- Java實(shí)現(xiàn)分頁(yè)的前臺(tái)頁(yè)面和后臺(tái)代碼
- java仿百度假分頁(yè)代碼實(shí)現(xiàn)的詳解
相關(guān)文章
Java 異步回調(diào)機(jī)制實(shí)例分析
這篇文章主要介紹了Java 異步回調(diào)機(jī)制實(shí)例解析的相關(guān)資料,需要的朋友可以參考下2017-02-02淺談synchronized方法對(duì)非synchronized方法的影響
下面小編就為大家?guī)?lái)一篇淺談synchronized方法對(duì)非synchronized方法的影響。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10springBoot使用openfeign來(lái)遠(yuǎn)程調(diào)用的實(shí)現(xiàn)
這篇文章主要介紹了springBoot使用openfeign來(lái)遠(yuǎn)程調(diào)用的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03springboot+mybatis配置控制臺(tái)打印sql日志的方法
這篇文章主要介紹了springboot+mybatis配置控制臺(tái)打印sql日志的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08JavaWeb Session失效時(shí)間設(shè)置方法
這篇文章主要介紹了JavaWeb Session失效時(shí)間設(shè)置方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12