MongoDB - 如何对对象内的多个属性进行查询并对结果进行分组

2024-01-11

I'm trying学习 MongoDB,但我似乎不知道如何做到这一点。

假设我有三个这样的对象:

         {
            "_id": 99990,
            "type" : 15,
            "attributes": [
                {
                    "id": 1,
                    "value": 115
                }
            ]
        },
        {
            "_id": 99991,
            "type" : 5,
            "attributes": [
                {
                    "id": 1,
                    "value": 120
                }
            ]
        },
        {
            "_id": 99992,
            "type" : 5,
            "attributes": [
                {
                    "id": 1,
                    "value": 120
                }
            ]
        },
        {
            "_id": 99993,
            "type" : 5,
            "attributes": [
                {
                    "id": 1,
                    "value": 150
                }
            ]
        },

如何根据属性“id”1 和值为 150 搜索项目并仅返回 id 99993 ?我今天刚刚开始使用 MongoDB,所以这可能是一个非常基本的问题。

为了增加挑战,我如何按属性/id/值对类型 5 的每个项目的结果进行分组,并获得如下结果:

 "id" : 1, "value" : 150, "count" : 1
 "id" : 1, "value" : 120: "count" : 2

这只是示例数据,模式非常复杂,但对于本练习的目的来说,它应该足够了。


对于第一部分,您应该能够通过执行以下操作来检索该记录:

db.collectionName.find({"attributes.id": 1, "attributes.value": 150});

这将从任何具有 id = 1 且 value = 150 的属性数组元素的对象中仅检索 _id 字段。

由于问题的第二部分涉及返回匹配项的计数,因此您应该探索您的选择映射减少 http://www.mongodb.org/display/DOCS/MapReduce。您无法通过简单的 Mongo 查询生成该结果。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MongoDB - 如何对对象内的多个属性进行查询并对结果进行分组 的相关文章

随机推荐

  • 使用 Knockout foreach 绑定嵌套数组

    我需要帮助使用淘汰 foreach 绑定嵌套数组 下面是代码 想知道如何获取 PatAppointments 数组中的元素
  • 仅当传入值时才执行Where条件

    我有以下 LINQ 语句where on the date and a LabID 我正在传递实验室列表和日期 但是它们不是必需的 并且我可能只传递日期 而不传递实验室 在这种情况下 我想获取该特定实验室的所有实验室的结果 这是我现在所拥有
  • 删除位图的黑色背景颜色

    我需要在 C VS2013 中删除位图的黑色背景颜色 就像我在画布上画一些点一样 这canvas是黑色的 我只需要将画布更改为透明的同时保持其上的彩色点不做任何改变 我在以下位置得到了解决方案 如何从位图中删除白色背景色 https sta
  • 如何在 Windows 服务中使用 Threadpool.QueueUserWorkItem?

    我有一个 Windows 服务 正在使用 Threadpool QueueUserWorkItem 该服务连接到多个客户端数据库 抓取数据 转换为 XLS 并将文件发送到相应的 FTP 我对下面的代码有 3 个问题 我是否正确使用 Thre
  • 使用 FParsec 解析方法参数

    我正在尝试使用 FParsec 实现方法参数解析器 我想知道 FParsec 本身是否有一些已经实现的功能可以帮助我实现此目的 我问这个问题是因为 FParsec 在处理运算符优先级时提供了工具 所以可能也有一些东西可以解决这个问题 解析左
  • Zend GetText 和 .mo .po 文件

    我继承了一家开发公司的应用程序 我需要为我的网站生成 mo 和 po 文件 这是我在引导程序中的内容 translate new Zend Translate gettext ROOT PATH languages en default m
  • C# - Visual Studion 2022 中的多行逐字字符串不包含换行符 (\r)

    我们在定义逐字多行字符串时面临问题 some string 在 Visual Studio 2022 中 虽然我们在 Windows 机器和变量上编译代码Environment NewLine定义 r n作为新行 逐字多行字符串仅包含 n
  • 在 Airflow GUI 外部创建连接

    我想在不与 Airflow GUI 交互的情况下创建 S3 连接 是否可以通过airflow cfg或命令行 我们正在使用 AWS 角色 以下连接参数适用于我们 aws account id xxxx role arn yyyyy 因此 在
  • 适合初学者的 Slim 框架 [关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 人们如何学习如何使用这个系统 我似乎找不到任何教程或书籍或任何有关如何使用该程序的内容 是的 他们的网站简要解释了一些事情 但没有任何澄清
  • 如何获取WebBrowser控件中的页面标题?

    当我导航到不同的网站时 如何获取 WebBrowser 控件中的页面标题 xmlns xmlns phone clr namespace Microsoft Phone Controls assembly Microsoft Phone 以
  • 为什么Android要求包名至少有两个标识符?

    创建新的 Android 应用程序时 Eclipse http androidcodingtips blogspot com 2011 08 package name must have at least two html抱怨Package
  • 解析附近时 JSON 中位置 XXX 出现意外标记的错误

    I npm install在一个目录上package json对于我的公司项目 然而 它不断给我带来各种错误 Unexpected token in JSON at position 我已经做好了npm cache clean force
  • 在 Bootstrap 3 中启用触摸事件的推荐方法?

    既然 Bootstrap 3 已经发布 那么启用触摸的推荐选项是什么 像之前一样 https stackoverflow com questions 16759299 is twitter bootstrap suitable for to
  • 音频播放完毕后通知

    嗯 我正在尝试实现录音的基本功能 例如 录音 播放 暂停 停止 我可以完成所有这些 但唯一的问题是音频完成后如何收到通知 玩 我的意思是 如果我播放一个音频文件 那么一旦它播放完毕 我想要一个它现在停止的通知 到目前为止我已经用过 mPla
  • 在 Roxygen 中记录时:如何在 @details 中制作逐项列表?

    例如 在 details 部分中向 roxygen2 添加逐项列表的适当语法是什么 我可以创建一个 Latex 列表环境吗 似乎换行符被简单地忽略了 即 details text describing parameter inputs in
  • 错误@angular/fire构建错误地扩展了接口

    我开始新的 Ionic Angular 项目并添加 Angular Fire 包 当我运行 ionicserve 时 出现以下错误 Error node modules angular fire compat firestore inter
  • 忽略全局覆盖的 new/delete

    您好 我正在使用一个已全局覆盖 new delete 的库 但我对这个库有一个问题 问题是它必须在主函数中手动初始化 现在我尝试使用另一个库在调用 main 之前初始化一些函数 不幸的是这个库在这些函数中使用了 new 所以我收到错误 因为
  • 需要建议新的 AsyncTask 递归调用

    我需要建议这个解决方案是否可以接受并且不会导致溢出 我更新使用 AsyncTask 读取的数据 在 AsyncTask 完成后我需要一次又一次更新 该解决方案是否可以接受且安全 private class DownloadFilesTask
  • 如何在sql中转义“'”

    您好 我正在数据库中搜索名称组合 我传递的组合如下 firstName firstName middleName middleName lastName lastName 这很好用 但问题来了 名字里有一些 我该如何纠正呢 例如 Johns
  • MongoDB - 如何对对象内的多个属性进行查询并对结果进行分组

    I m trying学习 MongoDB 但我似乎不知道如何做到这一点 假设我有三个这样的对象 id 99990 type 15 attributes id 1 value 115 id 99991 type 5 attributes