行业资讯 2025年08月6日
0 收藏 0 点赞 992 浏览 1905 个字
摘要 :

文章目录 一、需求场景 二、实现方案 三、涨点知识 本文主要讲解关于MongoDB根据Document中List类型的Field分页查询相关内容,让我们来一起学习下吧! 一、需求场景 就……




  • 一、需求场景
  • 二、实现方案
  • 三、涨点知识

本文主要讲解关于MongoDB根据Document中List类型的Field分页查询相关内容,让我们来一起学习下吧!

一、需求场景

就是个列表展示的分页查询,只不过数据是存在MongoDB中的,存的格式如下:

{
  \"modifyUser\": \"test\",
  \"createUser\": \"test\",
  \"action\":\"SKIP\"
  \"detail\": [
    \"1234\",
    \"5938\",
    \"6189\",
    \"6549\",
    \"7932\",
    \"7933\",
    // 此处省略若干条
    .......
  ]
},
{
  \"modifyUser\": \"test\",
  \"createUser\": \"test\",
  \"action\":\"INCLUDE\"
  \"detail\": [
    \"7696\",
    \"0986\",
    \"7654\",
    \"0985\",
    \"3457\",
    \"0985\",
    // 此处省略若干条
    .......
  ]
}

前台页面要求如下展示:MongoDB根据Document中List类型的Field分页查询

这意味着要根据数据库中每一条数据的detail字段进行分页查询。

二、实现方案

话不多说,直接看最终的实现方案:

public List<DO> pageQuery(Request request){
    
    // 根据自己的入参构造查询条件
    Criteria criteria = buildCriteria(request);

    Aggregation aggregation = Aggregation.newAggregation(
            match(criteria),
            unwind(\"detail\", true),
            sort(Sort.Direction.ASC, \"detail\"),
            skip((queryRequest.getPageIndex().longValue() - 1) * queryRequest.getPageSize()),
            limit(queryRequest.getPageSize())
    );

    return mongoTemplate.aggregate(aggregation, \"table\", DO.class).getMappedResults();
}

三、涨点知识

aggregate()是MongoDB的聚合函数,Aggregation是与之对应的聚合框架,主要用于对多个document的数据进行各种聚合计算,以返回最终需要的结果。

以上面的数据和实现方案为例,看看每一步都做了些什么?

 Aggregation aggregation = Aggregation.newAggregation(
        match(criteria),
        unwind(\"detail\", true),
        sort(Sort.Direction.ASC, \"detail\"),
        skip((queryRequest.getPageIndex().longValue() - 1) * queryRequest.getPageSize()),
        limit(queryRequest.getPageSize())
);

将上述代码转换为MongoDB的SQL:

db.test_table.aggregate(
    [
        { $match : {action:\"SKIP\"} },
        { $unwind: {path: \"$detail\",preserveNullAndEmptyArrays: true} },
        { $sort: {\"detail\"} },
        { $skip: 0 },
        { $limit: 10 },
    ] );

主要看一下前两步做了什么:

$match匹配过滤条件,将符合条件的文档筛选出来,$unwind将筛选后的结果中的detail进行拆分,每一条包含一个数组中的值。再经过排序,限制输出条数等操作,得到我们想要的结果。MongoDB根据Document中List类型的Field分页查询

MongoDB中常用的聚合操作:

操作 说明 与SQL对照
$match 过滤数据,筛选出符合条件的文档 WHERE
$project 修改输入文档的结构。可以用来重命名、增加或删除field SELECT
$unwind 将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值
$limit 用来限制MongoDB聚合管道返回的文档数 LIMIT
$skip 在聚合管道中跳过指定数量的文档
$group 将集合中的文档分组 GROUP BY
$sort 将输入文档排序后输出 ORDER BY
$lookup 连表查询,将被关联集合添加到执行操作的集合中 JOIN

以上就是关于MongoDB根据Document中List类型的Field分页查询相关的全部内容,希望对你有帮助。欢迎持续关注潘子夜个人博客(www.panziye.com),学习愉快哦!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/10047.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号