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页。
- 客户端请求:
如果什么参数都不传:
GET /orginfo/all
就用服务端接口定义的默认值,也就是以name排序,返回第0页,返回10条数据。
也可以这样请求:
GET /orginfo/all?size=100&page=3&sort=id,asc&sort=name,desc
以id正向排序再以name倒序排序,请求第3页,返回100条数据。
网友评论