Spring Mongo分页获取方式(附基础MongoTemplate使用案例)

本文介绍了如何在Spring应用中使用MongoTemplate进行分页查询,通过创建PageRequest和Sort对象,处理大量数据的问题。示例展示了在Service层和Repository层的实现,以及如何利用PageableExecutionUtils获取Page信息,并将结果转换为自定义的Pagination DTO返回给前端。
摘要由CSDN通过智能技术生成

在向应用获取数据的接口通常会面临的一个问题是,获取的数据量级过大。前端无法全部展示。
譬如一个日志系统中,前端需要查询一些日志信息就会遇到这样的问题。
这个时候可以使用分页的方式,既方便前端页面展示,又避免回复数据的大小过大。

下面贴一个简单的使用案例。
首先在我们的service层根据controller层传进来pageSize及currentPage做一个PageRequest

        PageRequest pageRequest = PageRequest
                .of(currentPage, pageSize, Sort.by(Sort.Direction.DESC, "createTimestamp"));

这里用到了org.springframework.data.domain.PageRequest和org.springframework.data.domain.Sort

然后再在Storage层中的Query添加使用PageRequest

    public Page<SomeClass> paginatedRetrieveAlert(
            String condition,
            Long startTimestamp,
            Long endTimestamp,
            PageRequest pageRequest) {
   
        Query query = new Query();

        if (condition != null && !condition.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值