Pagehelper获取total错误解决方案
问题描述及解决方案1、如下配置BaseService分页total总数正常,但是返回的实体为mapper层实体,与需求不一致,因此进行了调整import com.github.pagehelper.PageHelper;import com.github.pagehelper.PageInfo;import java.util.List;/*** @param <Param> 泛型re
文章共1,471字 · 阅读需要大约5分钟
一键AI生成摘要,助你高效阅读
问答
·
问题描述及解决方案
1、如下配置BaseService分页total总数正常,但是返回的实体为mapper层实体,与需求不一致,因此进行了调整
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import java.util.List;
/**
* @param <Param> 泛型request
* @param <Result> 泛型response
*/
public interface BaseService<Param, Result> {
/**
* 分页查询
*
* @param param 请求参数DTO
* @return 分页集合
*/
default PageInfo<Result> page(PageParam<Param> param) {
return PageHelper.startPage(param).doSelectPageInfo(() -> list(param.getParam()));
}
/**
* 集合查询
*
* @param param 查询参数
* @return 查询响应
*/
List<Result> list(Param param);
}
2、调整如下后,返回数据类型满足,但是出现了total总数等于每页数量问题
/**
* @param <Param> 泛型request
* @param <Result> 泛型response
*/
public interface BaseService<Param, Result> {
/**
* 分页查询
*
* @param param 请求参数DTO
* @return 分页集合
*/
default PageInfo<Result> page(PageParam<Param> param) {
PageHelper.startPage(param);
List<Result> list = parse(list(param.getParam()));
PageInfo<Result> pageInfo = new PageInfo<>(list);
return pageInfo;
}
/**
* 集合查询
*
* @param param 查询参数
* @return 查询响应
*/
List<Result> list(Param param);
/**
* 补充SO层字段
*
* @param mapperResult
* @return
*/
List<Result> parse(Collection mapperResult);
}
3、再次进行调整
Page page = PageHelper.startPage(pageNum, pageSize);
//使用page的getTotal()
int total = page.getTotal();
4、最终的BaseService如下
/**
* @param <Param> 泛型request
* @param <Result> 泛型response
*/
public interface BaseService<Param, Result> {
/**
* 分页查询
*
* @param param 请求参数DTO
* @return 分页集合
*/
default PageInfo<Result> page(PageParam<Param> param) {
Page page = PageHelper.startPage(param);
List<Result> list = parse(list(param.getParam()));
long total = page.getTotal();//一定要在获取list之后取total
PageInfo<Result> pageInfo = new PageInfo<>(list);
pageInfo.setTotal(total);
return pageInfo;
}
/**
* 集合查询
*
* @param param 查询参数
* @return 查询响应
*/
List<Result> list(Param param);
/**
* 补充SO层字段
*
* @param mapperResult
* @return
*/
List<Result> parse(Collection mapperResult);
}
5、如果各位大佬还有更好的解决方式,还请留下您宝贵的建议!
更多推荐
已为社区贡献2条内容
所有评论(0)