java中List分頁的幾種方法介紹
1.根據(jù)入?yún)Х猪搮?shù)進(jìn)行sql查詢分頁
Criteria criteria = new Criteria();
//將dataAuto轉(zhuǎn)成 factoryId brandId seriesId 等查詢條件
String dataAuth = "";
TypeCaseHelper.dataAuto(criteria, dataAuth);
// 設(shè)置分頁信息
ExtPager pager = new ExtPager();
Integer startTure = start * pageSize;
criteria.setMysqlPageSize(pageSize);
criteria.setMysqlStart(startTure);
// 排序信息
if (StringUtils.isNotBlank(pager.getDir()) && StringUtils.isNotBlank(pager.getSort())) {
criteria.setOrderByClause(pager.getSort() + " " + pager.getDir());
}
List<VhlAlarmStatusMgtEntity> listDistinct = getVhlAlarmStatusMgtEntities(vin, faultStatus, confirmStatus, startDateTime, endDateTime, sdf, sdfm, carTypeList, criteria);
對應(yīng)的分頁sql
<select id="selectByExample" parameterType="Criteria" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from status_mgt
<where>
<if test="condition.carTypeList != null and condition.carTypeList.size() > 0" >
and car_type in
<foreach collection="condition.carTypeList" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</if>
<if test="condition.startDateTime != null and condition.startDateTime!=''">
and alarm_time >= str_to_date(#{condition.startDateTime,jdbcType=VARCHAR},'%Y-%m-%d %H:%i:%S')
</if>
<if test="condition.endDateTime != null and condition.endDateTime!=''">
and str_to_date(#{condition.endDateTime,jdbcType=VARCHAR},'%Y-%m-%d %H:%i:%S') >= alarm_time
</if>
and logic_flag = 1
</where>
order by alarm_time desc
<if test="mysqlStart != null and mysqlPageSize != null">
limit #{mysqlStart}, #{mysqlPageSize}
</if>
</select>
2.對所有l(wèi)ist根據(jù)分頁參數(shù)分頁
Criteria criteria1 = new Criteria();
List<VhlAlarmStatusMgtEntity> listDistinctForCout = getVhlAlarmStatusMgtEntities(vin, faultStatus, confirmStatus, startDateTime, endDateTime, sdf, sdfm, carTypeList, criteria1);
Integer count = listDistinctForCout.size(); // 記錄總數(shù)
Integer pageCount; // 頁數(shù)
if (count % pageSize == 0) {
pageCount = count / pageSize;
} else {
pageCount = count / pageSize + 1;
}
int fromIndex; // 開始索引
int toIndex; // 結(jié)束索引
if (!pageCount.equals(start+1)) {
fromIndex = start * pageSize;
toIndex = fromIndex + pageSize;
if(toIndex > count){
fromIndex = (start-1) * pageSize;
toIndex = count;
}
} else {
fromIndex = start * pageSize;
toIndex = count;
}
List<VhlAlarmStatusMgtEntity> pageList = listDistinctForCout.subList(fromIndex, toIndex);
3.PageHelper分頁
//開啟分頁
PageHelper.startPage(Integer.parseInt(pageNum), Integer.parseInt(pageSize));
PageInfo<Map<String, String>> pageInfo = new PageInfo(datalist);
HashMap<String, Object> map= new HashMap<>();
map.put("datalist", datalist);
map.put("total", pageInfo.getTotal());
map.put("size", pageInfo.getPageSize());
map.put("page", pageInfo.getPageNum());
到此這篇關(guān)于java中List分頁的幾種方法介紹的文章就介紹到這了,更多相關(guān)java List分頁方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Java 中的 Lambda 表達(dá)式
這篇文章主要介紹了關(guān)于Java 中的 Lambda 表達(dá)式,Lambda 表達(dá)式是 Java 涉足函數(shù)式編程的過程。它接受參數(shù)并將其應(yīng)用于表達(dá)式或代碼塊,下面一起進(jìn)入文章查看詳細(xì)內(nèi)容2021-11-11
如何在Java SpringBoot項(xiàng)目中配置動態(tài)數(shù)據(jù)源你知道嗎
這篇文章主要介紹了SpringBoot如何在運(yùn)行時(shí)動態(tài)添加數(shù)據(jù)源,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-09-09
Java編程細(xì)節(jié)重構(gòu)之為什么if-else不是好代碼詳析
這篇文章主要給大家介紹了關(guān)于Java編程細(xì)節(jié)重構(gòu)之為什么if-else不是好代碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)些學(xué)習(xí)吧2018-09-09
Java設(shè)計(jì)模式之抽象工廠模式(Abstract?Factory)
這篇文章主要為大家詳細(xì)介紹了Java設(shè)計(jì)模式之抽象工廠模式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Java多線程中不同條件下編寫生產(chǎn)消費(fèi)者模型方法介紹
這篇文章主要介紹了Java多線程中不同條件下編寫生產(chǎn)消費(fèi)者模型方法介紹,介紹了生產(chǎn)消費(fèi)者模型,然后分享了相關(guān)代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11
Springboot中的@ConditionalOnBean注解使用指南與最佳實(shí)踐(工作原理)
在使用Spring Boot進(jìn)行開發(fā)時(shí),大家應(yīng)該都聽說過條件注解Conditional Annotations,下面給大家聊聊Springboot中的@ConditionalOnBean注解使用指南與最佳實(shí)踐,感興趣的朋友一起看看吧2025-05-05

