Pageable 前台传参

Pageable 是Spring Data库中定义的一个接口,该接口是所有分页相关信息的一个抽象,通过该接口,我们可以得到和分页相关所有信息(例如pageNumber、pageSize等)。

Pageable定义了很多方法,但其核心的信息只有两个:一是分页的信息(page、size),二是排序的信息。

在请求中只需要在方法的参数中直接定义一个pageable类型的参数,当Spring发现这个参数时,Spring会自动的根据request的参数来组装该pageable对象。
Spring支持的request参数如下:

page :第几页,从0开始,默认为第0页
size :每一页的大小,默认为10
sort :排序相关的信息,以`property[,ASC|DESC]`的方式组织,例如`sort=firstname&sort=lastname,desc`表示在按firstname正序排列基础上按lastname倒序排列。

下面举例说明:

  • 服务端代码
/**
     * 获取所有机构
     *
     * @return
     * @sort 排序字段,默认为name
     */
    @ApiOperation(value = "获取所有机构信息", tags = {"机构管理"})
    @GetMapping("/orginfo/all")
    public ResponseModel<Page> getAll(@PageableDefault(sort = {"name"}, direction = Sort.Direction.ASC) Pageable pageable) {
        Page<Org> orgs = orgInfoService.getAllOrg(pageable);
        return ResponseModel.ok().setBody(orgs);
    }

可以看下@PageableDefault注解的源码定义:

package org.springframework.data.web;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.data.domain.Sort.Direction;

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.PARAMETER})
public @interface PageableDefault {
    int value() default 10;

    int size() default 10;

    int page() default 0;

    String[] sort() default {};

    Direction direction() default Direction.ASC;
}

@PageableDefault(sort = {"name"}, direction = Sort.Direction.ASC) 注解表示默认以name正向排序,size默认为10个,page默认为第0页。

请注意:@PageableDefault注释也有一个sort属性,但如果我们要定义多个字段以按不同方向排序,我们必须使用@SortDefault。

/**
     * 获取所有机构
     *
     * @return
     * @sort 排序字段,默认为name
     */
    @ApiOperation(value = "获取所有机构信息", tags = {"机构管理"})
    @GetMapping("/orginfo/all")
    public ResponseModel<Page> getAll(@PageableDefault(page = 0, size = 20) @SortDefault.SortDefaults({@SortDefault(sort = "name", direction = Sort.Direction.DESC), @SortDefault(sort = "id", direction = Sort.Direction.ASC)}) Pageable pageable) {
        Page<Org> orgs = orgInfoService.getAllOrg(pageable);
        return ResponseModel.ok().setBody(orgs);
    }
  • 客户端请求:
    如果什么参数都不传:
GET /orginfo/all

就用服务端接口定义的默认值,也就是以name排序,返回第0页,返回10条数据。

也可以这样请求:

GET /orginfo/all?size=100&page=3&sort=id,asc&sort=name,desc

以id正向排序再以name倒序排序,请求第3页,返回100条数据。

tips: 针对mysql数据库,中文字段排序可能不是按照拼音来排序的,可以把排序字段做一下特殊处理CONVERT(name USING GBK),如下

GET /orginfo/all?size=100&page=3&sort=id,asc&sort=CONVERT(name+USING+GBK),desc
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,711评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,290评论 6 342
  • 绵绵连连秋雨剪不断, 萧萧索索落叶理还乱。 最是美景层林尽皆染, 不若葬花寒冬愚人言。 说不出道不明勘破难, 一人...
    王的森林阅读 242评论 0 0
  • 斯坦·李:我最骄傲的是,也许我做的一些事情能娱乐到他人。
    shelllllly阅读 139评论 0 0
  • 前一天晚上才最终决定去参加,之前一直在纠结,这一点来说特别感谢张阳姐的沙龙和俊英姐的鼓励。 最大的收获是自己上台分...
    Interesting7阅读 549评论 0 2

友情链接更多精彩内容