Spring Data MongoDB 分页查询

Posted skiwnchqhh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring Data MongoDB 分页查询相关的知识,希望对你有一定的参考价值。

在上篇文章 Spring Data MongoDB 环境搭建 基础上进行分页查询

定义公用分页参数类,实现 Pageable 接口

import java.io.Serializable;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;

public class SpringDataPageable implements Serializable, Pageable {
    private static final long serialVersionUID = 1;
    // 当前页
    private Integer pagenumber = 1;
    // 当前页面条数
    private Integer pagesize = 10;
    // 排序条件
    private Sort sort;

    // 当前页面
    @Override
    public int getPageNumber() {
        return getPagenumber();
    }

    // 每一页显示的条数
    @Override
    public int getPageSize() {
        return getPagesize();
    }

    // 第二页所需要增加的数量
    @Override
    public int getOffset() {
        return (getPagenumber() - 1) * getPagesize();
    }

    @Override
    public Sort getSort() {
        return sort;
    }

    public Integer getPagenumber() {
        return pagenumber;
    }

    public void setPagenumber(Integer pagenumber) {
        this.pagenumber = pagenumber;
    }

    public Integer getPagesize() {
        return pagesize;
    }

    public void setPagesize(Integer pagesize) {
        this.pagesize = pagesize;
    }

    public void setSort(Sort sort) {
        this.sort = sort;
    }

    @Override
    public Pageable first() {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public boolean hasPrevious() {
        // TODO Auto-generated method stub
        return false;
    }

    @Override
    public Pageable next() {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public Pageable previousOrFirst() {
        // TODO Auto-generated method stub
        return null;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80

接口 PersonDao

/**
 * 分页查询
 * @param pageNum  开始页
 * @return
 */
public Page<Person> paginationQuery(Integer pageNum);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

接口实现 PersonDaoImpl

public Page<Person> paginationQuery(Integer pageNum) {

    SpringDataPageable pageable = new SpringDataPageable();
    Query query = new Query();
    List<Order> orders = new ArrayList<Order>();  //排序
    orders.add(new Order(Direction.DESC, "age"));
    Sort sort = new Sort(orders);

    // 开始页
    pageable.setPagenumber(pageNum);
    // 每页条数
    pageable.setPagesize(10);
    // 排序
    pageable.setSort(sort);
    // 查询出一共的条数
    Long count = mongoTemplate.count(query, Person.class);
    // 查询
    List<Person> list = mongoTemplate.find(query.with(pageable), Person.class);
    // 将集合与分页结果封装
    Page<Person> pagelist = new PageImpl<Person>(list, pageable, count);

    return pagelist;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

测试

/**
 * 分页查询
 */
@Test
public void paginationQuery(){
    Page<Person> persons = personDao.paginationQuery(2);
    for(Person p : persons){
        System.out.println(p.getName());
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

作者:itmyhome

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

以上是关于Spring Data MongoDB 分页查询的主要内容,如果未能解决你的问题,请参考以下文章

Mongodb系列- 使用spring-data-mongodb实现分页查询

Spring Data MongoDB 五:进阶文档查询(分页Morphia)

Spring Data MongoDB聚合分页查询中SkipOPeration和LimitOperation的位置

如何利用spring data mongodb 进行多条件查询

使用Spring Data Mongodb的MongoRepository类进行增删改查

如何在带有自定义过滤器的 Spring Data mongodb 中使用分页和排序?