Mybatis-plus配置分页插件返回统一结果集

目录

一、MyBatisPlusConfig中配置分页插件

1. 分页实现的原理

二、统一结果集

1. 创建返回码定义类

2. 创建结果集类

三、编写分页接口

1. 先编写查询类

2. service层

3. controller层

4. 接口测试

总结

一、MyBatisPlusConfig中配置分页插件 /** * 配置分页插件 * @return page */ @Bean public PaginationInterceptor paginationInterceptor(){ PaginationInterceptor paginationInterceptor = new PaginationInterceptor(); // 开启 count 的 join 优化,只针对部分 left join paginationInterceptor.setCountSqlParser(new JsqlParserCountOptimize(true)); return paginationInterceptor; } 1. 分页实现的原理

Mybatis-plus分页插件使用的是IPage进行分页。IPage内部原理是基于拦截器,拦截的是方法以及方法中的参数。判断是否是查询操作,如果是查询操作,才会进入分页的处理逻辑。 进入分页逻辑处理后,拦截器会通过反射获取该方法的参数进行判断是否存在IPage对象的实现类。如果不存在则不进行分页,存在则将该参数赋值给IPage对象,然后进行拼接sql的处理完成分页操作。

二、统一结果集 1. 创建返回码定义类 public class ResultCode { /** * 成功 **/ public final static int OK = 20000; /** * 失败 **/ public final static int ERROR = 20001; /** * 用户名或密码错误 **/ public final static int LOGIN_ERROR = 20002; /** * 权限不足 **/ public final static int ACCESS_ERROR = 20003; /** * 远程调用失败 **/ public final static int REMOTE_ERROR = 20004; /** * 重复操作 **/ public final static int REPEAT_ERROR = 20005; } 2. 创建结果集类 @Data @ApiModel(value = "全局统一返回结果") public class R implements Serializable { public final static String OK_MSG = "请求成功"; public final static String FAIL_MSG = "请求失败"; @ApiModelProperty(value = "是否成功") private boolean success; @ApiModelProperty(value = "返回码") private Integer code; @ApiModelProperty(value = "返回消息") private String message; @ApiModelProperty(value = "返回数据") private Object data; @ApiModelProperty(value = "总条数") private Long total; @ApiModelProperty(value = "分页信息") private PageInfo pageInfo; @Data public static class PageInfo { @ApiModelProperty("当前页") protected int currentPage; @ApiModelProperty("页大小") protected int pageSize; @ApiModelProperty("总记录数") protected long totalCount; @ApiModelProperty("总页数") protected long totalPage; public PageInfo() { } @ConstructorProperties({"currentPage", "pageSize", "totalCount", "totalPage"}) public PageInfo(int currentPage, int pageSize, long totalCount, long totalPage) { this.currentPage = currentPage; this.pageSize = pageSize; this.totalCount = totalCount; this.totalPage = totalPage; } } private R(){} private R(int code, String msg, Object data) { this.code = code; this.message = msg; if (data instanceof Page<?>) { Page<?> page = (Page<?>) data; this.total = page.getTotal(); this.data = page.getRecords(); this.pageInfo = new PageInfo((int)page.getCurrent(), (int)page.getSize(), page.getTotal(), page.getPages()); } else { this.data = data; } } public static R ok(){ R r = new R(); r.setSuccess(true); r.setCode(ResultCode.OK); r.setMessage("成功"); return r; } public static R ok(Object data) { return new R(ResultCode.OK, OK_MSG, data); } public static R ok(String msg, Object data) { return new R(ResultCode.OK, msg, data); } public static R error(){ R r = new R(); r.setSuccess(false); r.setCode(ResultCode.ERROR); r.setMessage("失败"); return r; } public static R error(String msg) { return new R(ResultCode.ERROR, msg, null); } public static R error(int errorCode, String msg) { return new R(errorCode, msg, null); } public R message(String message){ this.setMessage(message); return this; } public R code(Integer code){ this.setCode(code); return this; } public R data(Object data){ this.setData(data); return this; } } 三、编写分页接口 1. 先编写查询类

代码如下:

@Data public class MemberQueryVo extends BasePageEntity{ @ApiModelProperty(value = "用户名") private String userName; } 2. service层

先定义一个查询分页的接口,在实现类里做相关处理

@Service public class MemberServiceImpl extends ServiceImpl<MemberMapper, Member> implements MemberService { @Override public IPage<Member> listMemberPage(MemberQueryVo queryVo) { IPage<Member> page = new Page<>(queryVo.getCurrentPage(),queryVo.getCurrentPage()); //条件查询 LambdaQueryWrapper<Member> queryWrapper = new LambdaQueryWrapper<Member>(); if (StringUtils.isNotBlank(queryVo.getUserName())) { queryWrapper.like(Member::getUserName, queryVo.getUserName()); } return baseMapper.selectPage(page,queryWrapper); } } 3. controller层

编写分页接口,代码如下:

@ApiOperation(value = "分页用户列表") @GetMapping(value = "/getPage") public R listPage(MemberQueryVo queryVo){ IPage<Member> page = memberService.listMemberPage(queryVo); return R.ok(page); } 4. 接口测试

直接通过swagger生成的api接口页面进行测试,当前页、每页参数传1时,返回的分页信息里,总数是两条,只返回了一条数据。说明分页成功。

再进行条件查询的时候,也成功查询对应数据。

再进行条件查询的时候,也成功查询对应数据。

总结

感谢大家的阅读,上就是今天要讲的内容,本文简单介绍了如何配置分页插件、以及分页的原理。如有不足之处,纯属能力有限,还请多多包涵。

到此这篇关于Mybatis-plus配置分页插件返回统一结果集的文章就介绍到这了,更多相关Mybatis-plus分页返回统一结果集内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    学习写字楼新选择6000元主流配置

    学习写字楼新选择6000元主流配置,,这种配置需要考虑双核心的办公和娱乐平台,充分考虑办公室的办公需求和娱乐需求,以约6000元的预算和cost-e

    酷睿I7 配置

    酷睿I7 配置,配置,玩家国度啦华硕 Rampage II Extreme(3800元)如果米不够,也可以把Extreme改为Gene,不过是小板内存推荐金士顿6G DDR3 2000骇

    提高3A四核羿龙II游戏配置的性能

    提高3A四核羿龙II游戏配置的性能,,以节能环保为主题的IT产业,目前3A低端平台处理器、主板芯片组、独立开发卡性能突出,特别是在与AMD的处理

    opporeno8参数配置及价格

    opporeno8参数配置及价格,面部,亿元,Oppo的荣誉2020年1月4日,接近屏幕关闭传感器是否支持双卡:支持oppor11splus什么时候上市的Oppo R11S P

    查看配置:酷睿i3530集展示办公平台

    查看配置:酷睿i3530集展示办公平台,,由于时间和精力的关系,我们不可能对所有的配置进行评论,希望我们能理解,我希望我们的评论能在那些需要帮

    3500元超额值学生娱乐结构的优化配置

    3500元超额值学生娱乐结构的优化配置,,作为一个DIY的主流用户领域的学生,每个用户51学生攒机的高峰。因为学生用户没有稳定的收入来源,攒机

    电脑配置快捷键|查看电脑配置快捷键

    电脑配置快捷键|查看电脑配置快捷键,,查看电脑配置快捷键1.在win10中,快捷键组合win+E已经变成了“快速访问”,不再是以前的“我的电脑了”2