mirror of
https://gitee.com/mybatis-flex/mybatis-flex.git
synced 2025-12-08 09:38:26 +08:00
!150 fix: 为 pageNumber 和 pageSize 添加默认值
Merge pull request !150 from 王帅/main
This commit is contained in:
commit
60589efea6
@ -74,6 +74,11 @@ public class FlexGlobalConfig {
|
|||||||
private Object normalValueOfLogicDelete = FlexConsts.LOGIC_DELETE_NORMAL;
|
private Object normalValueOfLogicDelete = FlexConsts.LOGIC_DELETE_NORMAL;
|
||||||
private Object deletedValueOfLogicDelete = FlexConsts.LOGIC_DELETE_DELETED;
|
private Object deletedValueOfLogicDelete = FlexConsts.LOGIC_DELETE_DELETED;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分页查询时,默认每页显示的数据数量。
|
||||||
|
*/
|
||||||
|
private int defaultPageSize = 10;
|
||||||
|
|
||||||
public boolean isPrintBanner() {
|
public boolean isPrintBanner() {
|
||||||
return printBanner;
|
return printBanner;
|
||||||
}
|
}
|
||||||
@ -307,6 +312,14 @@ public class FlexGlobalConfig {
|
|||||||
this.deletedValueOfLogicDelete = deletedValueOfLogicDelete;
|
this.deletedValueOfLogicDelete = deletedValueOfLogicDelete;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getDefaultPageSize() {
|
||||||
|
return defaultPageSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDefaultPageSize(int defaultPageSize) {
|
||||||
|
this.defaultPageSize = defaultPageSize;
|
||||||
|
}
|
||||||
|
|
||||||
public static ConcurrentHashMap<String, FlexGlobalConfig> getGlobalConfigs() {
|
public static ConcurrentHashMap<String, FlexGlobalConfig> getGlobalConfigs() {
|
||||||
return globalConfigs;
|
return globalConfigs;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -15,6 +15,8 @@
|
|||||||
*/
|
*/
|
||||||
package com.mybatisflex.core.paginate;
|
package com.mybatisflex.core.paginate;
|
||||||
|
|
||||||
|
import com.mybatisflex.core.FlexGlobalConfig;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@ -22,46 +24,111 @@ import java.util.List;
|
|||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 分页对象
|
* 分页对象封装。
|
||||||
*
|
*
|
||||||
* @param <T> 对象类型
|
* @param <T> 数据类型
|
||||||
|
* @author 开源海哥
|
||||||
|
* @author 王帅
|
||||||
*/
|
*/
|
||||||
public class Page<T> implements Serializable {
|
public class Page<T> implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
public static final int INIT_VALUE = -1;
|
public static final int INIT_VALUE = -1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 当前页数据。
|
||||||
|
*/
|
||||||
private List<T> records = Collections.emptyList();
|
private List<T> records = Collections.emptyList();
|
||||||
private int pageNumber = INIT_VALUE;
|
|
||||||
private int pageSize = INIT_VALUE;
|
/**
|
||||||
|
* 当前页码。
|
||||||
|
*/
|
||||||
|
private int pageNumber = 1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 每页数据数量。
|
||||||
|
*/
|
||||||
|
private int pageSize = FlexGlobalConfig.getDefaultConfig().getDefaultPageSize();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 总页数。
|
||||||
|
*/
|
||||||
private long totalPage = INIT_VALUE;
|
private long totalPage = INIT_VALUE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 总数据数量。
|
||||||
|
*/
|
||||||
private long totalRow = INIT_VALUE;
|
private long totalRow = INIT_VALUE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否优化分页查询 COUNT 语句。
|
||||||
|
*/
|
||||||
private boolean optimizeCountQuery = true;
|
private boolean optimizeCountQuery = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建分页对象。
|
||||||
|
*
|
||||||
|
* @param pageNumber 当前页码
|
||||||
|
* @param pageSize 每页数据数量
|
||||||
|
* @param <T> 数据类型
|
||||||
|
* @return 分页对象
|
||||||
|
*/
|
||||||
public static <T> Page<T> of(int pageNumber, int pageSize) {
|
public static <T> Page<T> of(int pageNumber, int pageSize) {
|
||||||
return new Page<>(pageNumber, pageSize);
|
return new Page<>(pageNumber, pageSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建分页对象。
|
||||||
|
*
|
||||||
|
* @param pageNumber 当前页码
|
||||||
|
* @param pageSize 每页数据数量
|
||||||
|
* @param totalRow 总数据数量
|
||||||
|
* @param <T> 数据类型
|
||||||
|
* @return 分页对象
|
||||||
|
*/
|
||||||
public static <T> Page<T> of(int pageNumber, int pageSize, long totalRow) {
|
public static <T> Page<T> of(int pageNumber, int pageSize, long totalRow) {
|
||||||
return new Page<>(pageNumber, pageSize, totalRow);
|
return new Page<>(pageNumber, pageSize, totalRow);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建分页对象。
|
||||||
|
*/
|
||||||
public Page() {
|
public Page() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建分页对象。
|
||||||
|
*
|
||||||
|
* @param pageNumber 当前页码
|
||||||
|
* @param pageSize 每页数据数量
|
||||||
|
*/
|
||||||
public Page(int pageNumber, int pageSize) {
|
public Page(int pageNumber, int pageSize) {
|
||||||
this.setPageNumber(pageNumber);
|
this.setPageNumber(pageNumber);
|
||||||
this.setPageSize(pageSize);
|
this.setPageSize(pageSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建分页对象。
|
||||||
|
*
|
||||||
|
* @param pageNumber 当前页码
|
||||||
|
* @param pageSize 每页数据数量
|
||||||
|
* @param totalRow 总数居数量
|
||||||
|
*/
|
||||||
public Page(int pageNumber, int pageSize, long totalRow) {
|
public Page(int pageNumber, int pageSize, long totalRow) {
|
||||||
this.setPageNumber(pageNumber);
|
this.setPageNumber(pageNumber);
|
||||||
this.setPageSize(pageSize);
|
this.setPageSize(pageSize);
|
||||||
this.setTotalRow(totalRow);
|
this.setTotalRow(totalRow);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建分页对象。
|
||||||
|
*
|
||||||
|
* @param records 当前页数据
|
||||||
|
* @param pageNumber 当前页码
|
||||||
|
* @param pageSize 每页数据数量
|
||||||
|
* @param totalRow 总数居数量
|
||||||
|
*/
|
||||||
public Page(List<T> records, int pageNumber, int pageSize, long totalRow) {
|
public Page(List<T> records, int pageNumber, int pageSize, long totalRow) {
|
||||||
this.setRecords(records);
|
this.setRecords(records);
|
||||||
this.setPageNumber(pageNumber);
|
this.setPageNumber(pageNumber);
|
||||||
@ -69,7 +136,6 @@ public class Page<T> implements Serializable {
|
|||||||
this.setTotalRow(totalRow);
|
this.setTotalRow(totalRow);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取当前页的数据。
|
* 获取当前页的数据。
|
||||||
*
|
*
|
||||||
@ -79,7 +145,6 @@ public class Page<T> implements Serializable {
|
|||||||
return records;
|
return records;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置当前页的数据。
|
* 设置当前页的数据。
|
||||||
*
|
*
|
||||||
@ -101,7 +166,6 @@ public class Page<T> implements Serializable {
|
|||||||
return pageNumber;
|
return pageNumber;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置当前页码。
|
* 设置当前页码。
|
||||||
*
|
*
|
||||||
@ -114,7 +178,6 @@ public class Page<T> implements Serializable {
|
|||||||
this.pageNumber = pageNumber;
|
this.pageNumber = pageNumber;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取当前每页数据数量。
|
* 获取当前每页数据数量。
|
||||||
*
|
*
|
||||||
@ -124,7 +187,6 @@ public class Page<T> implements Serializable {
|
|||||||
return pageSize;
|
return pageSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置当前每页数据数量。
|
* 设置当前每页数据数量。
|
||||||
*
|
*
|
||||||
@ -165,7 +227,6 @@ public class Page<T> implements Serializable {
|
|||||||
return totalRow;
|
return totalRow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置数据总数。
|
* 设置数据总数。
|
||||||
*
|
*
|
||||||
@ -177,7 +238,7 @@ public class Page<T> implements Serializable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 计算总页码
|
* 计算总页码。
|
||||||
*/
|
*/
|
||||||
private void calcTotalPage() {
|
private void calcTotalPage() {
|
||||||
if (pageSize < 0 || totalRow < 0) {
|
if (pageSize < 0 || totalRow < 0) {
|
||||||
@ -187,7 +248,6 @@ public class Page<T> implements Serializable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 当前页是否为空。
|
* 当前页是否为空。
|
||||||
*
|
*
|
||||||
@ -197,7 +257,6 @@ public class Page<T> implements Serializable {
|
|||||||
return getTotalRow() == 0 || getPageNumber() > getTotalPage();
|
return getTotalRow() == 0 || getPageNumber() > getTotalPage();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 是否存在下一页。
|
* 是否存在下一页。
|
||||||
*
|
*
|
||||||
@ -207,7 +266,6 @@ public class Page<T> implements Serializable {
|
|||||||
return getTotalPage() != 0 && getPageNumber() < getTotalPage();
|
return getTotalPage() != 0 && getPageNumber() < getTotalPage();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 是否存在上一页。
|
* 是否存在上一页。
|
||||||
*
|
*
|
||||||
@ -217,7 +275,6 @@ public class Page<T> implements Serializable {
|
|||||||
return getPageNumber() > 1;
|
return getPageNumber() > 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取当前分页偏移量。
|
* 获取当前分页偏移量。
|
||||||
*
|
*
|
||||||
@ -227,7 +284,6 @@ public class Page<T> implements Serializable {
|
|||||||
return getPageSize() * (getPageNumber() - 1);
|
return getPageSize() * (getPageNumber() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置是否自动优化 COUNT 查询语句。
|
* 设置是否自动优化 COUNT 查询语句。
|
||||||
*
|
*
|
||||||
@ -237,7 +293,6 @@ public class Page<T> implements Serializable {
|
|||||||
this.optimizeCountQuery = optimizeCountQuery;
|
this.optimizeCountQuery = optimizeCountQuery;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 是否自动优化 COUNT 查询语句(默认优化)。
|
* 是否自动优化 COUNT 查询语句(默认优化)。
|
||||||
*
|
*
|
||||||
@ -247,7 +302,6 @@ public class Page<T> implements Serializable {
|
|||||||
return optimizeCountQuery;
|
return optimizeCountQuery;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public <R> Page<R> map(Function<? super T, ? extends R> mapper) {
|
public <R> Page<R> map(Function<? super T, ? extends R> mapper) {
|
||||||
Page<R> newPage = new Page<>();
|
Page<R> newPage = new Page<>();
|
||||||
newPage.pageNumber = pageNumber;
|
newPage.pageNumber = pageNumber;
|
||||||
@ -265,7 +319,6 @@ public class Page<T> implements Serializable {
|
|||||||
return newPage;
|
return newPage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Page{" +
|
return "Page{" +
|
||||||
|
|||||||
@ -249,13 +249,13 @@ class UserMapperTest {
|
|||||||
.leftJoin(USER_ROLE).as("ur").on(USER_ROLE.USER_ID.eq(USER.USER_ID))
|
.leftJoin(USER_ROLE).as("ur").on(USER_ROLE.USER_ID.eq(USER.USER_ID))
|
||||||
.leftJoin(ROLE).as("r").on(USER_ROLE.ROLE_ID.eq(ROLE.ROLE_ID));
|
.leftJoin(ROLE).as("r").on(USER_ROLE.ROLE_ID.eq(ROLE.ROLE_ID));
|
||||||
System.err.println(queryWrapper.toSQL());
|
System.err.println(queryWrapper.toSQL());
|
||||||
Page<UserVO> page = Page.of(1, 1);
|
Page<UserVO> page = new Page<>();
|
||||||
page.setOptimizeCountQuery(false);
|
page.setOptimizeCountQuery(false);
|
||||||
int pageNumber = 0;
|
int pageNumber = 0;
|
||||||
do {
|
do {
|
||||||
page.setPageNumber(page.getPageNumber() + 1);
|
|
||||||
page = userMapper.paginateAs(page, queryWrapper, UserVO.class);
|
page = userMapper.paginateAs(page, queryWrapper, UserVO.class);
|
||||||
System.err.println(page);
|
System.err.println(page);
|
||||||
|
page.setPageNumber(page.getPageNumber() + 1);
|
||||||
} while (page.hasNext());
|
} while (page.hasNext());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user