0

0

MongoDB 聚合:将二维数组转换为各子数组长度构成的一维数组

碧海醫心

碧海醫心

发布时间:2026-01-15 11:27:39

|

808人浏览过

|

来源于php中文网

原创

MongoDB 聚合:将二维数组转换为各子数组长度构成的一维数组

本文介绍如何使用 mongodb 聚合管道(特别是 `$map` 与 `$size`)将存储的二维数组(如用户答题结果)高效转换为对应子数组长度组成的一维数值数组,适用于动态长度的选项场景。

在构建在线测验(quiz)系统时,一种常见数据建模方式是将用户对各选项的选择结果以二维数组形式存储,例如:

{ "results": [["10938381", "10938382"], [], ["10938383", "10938384", "10938385"], ["10938386"]] }

其中 results[i] 表示第 i 个答案选项被选中的用户 ID 列表;数组长度即该选项的投票数。业务上常需快速统计每个选项的响应人数——即把上述结构映射为 [2, 0, 3, 1]。

MongoDB 原生支持函数式转换操作符,推荐使用 $map 配合 $size 实现该需求。$map 可遍历输入数组的每个元素(此处为每个子数组),而 $size 可安全计算任意数组长度(对空数组返回 0,无需额外判断)。

✅ 正确聚合表达式如下(兼容 Mongoose .aggregate()):

AI Content Detector
AI Content Detector

Writer推出的AI内容检测工具

下载
YourModel.aggregate([
  {
    $project: {
      results: {
        $map: {
          input: "$results",
          in: { $size: "$$this" }
        }
      }
    }
  }
])

? 关键说明

  • $$this 是 $map 的当前迭代变量,代表 results 中的每一个子数组;
  • $size 对非数组字段会报错,但本例中 results 明确定义为二维数组,因此安全;
  • 该方案完全动态:无论子数组数量是 2、4 还是 5 个,输出数组长度始终与输入一致,无需硬编码字段索引或使用 $switch 等冗余逻辑;
  • 在 Mongoose 中可直接链式调用,例如:Quiz.findOne().aggregate([...]).exec()。

⚠️ 注意事项:

  • 确保 results 字段在文档中始终为数组类型(建议在 Schema 中定义为 [[String]] 或 Array>,并启用 typeKey: '$type' 验证);
  • 若存在 null 或缺失 results 字段,可添加 $ifNull 防御:input: { $ifNull: ["$results", []] };
  • 如需同时返回原始选项列表(如 ["Strawberries", "Apples", ..."]),可在同一 $project 阶段一并保留或关联查表。

该方法简洁、高效、可读性强,是处理此类“数组长度映射”问题的标准实践。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

436

2024.03.01

switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

529

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

410

2024.03.13

switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

529

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

410

2024.03.13

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.7万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号