首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在mongoDB中按ID分组

在mongoDB中按ID分组
EN

Stack Overflow用户
提问于 2016-09-13 10:29:14
回答 1查看 128关注 0票数 0

有人能在mongodb中帮助我完成以下聚合操作吗?有一个包含ids和组ids的项目集合,将它们按组ids分组。例如,对于项的集合:

代码语言:javascript
复制
{
    "id": 1,
    "group_id": 10,
    "data": "some_data",
    "name": "first"
},
{
    "id": 2,
    "group_id": 10,
    "data": "some_data",
    "name": "second"
},
{
    "id": 3
    "group_id": 20,
    "data": "some_data",
    "name": "third"
}

创建具有以下结构的组的新集合:

代码语言:javascript
复制
    {
    "id": 10,
    "items": [
        {
            "id": 1,
            "group_id": 10,
            "data": "some_data",
            "name": "first"
        },
        {
            "id": 2,
            "group_id": 10,
            "data": "some_data",
            "name": "second"
        }
    ]
},
{
    "id": 10,
    "items": [
        {
            "id": 2,
            "group_id": 20,
            "data": "some_data",
            "name": "third"
        }
    ]
}

我们也会感谢Java和spring的相应片段。实际上,我现在对Java也做了同样的事情,并且希望将这个逻辑转移到mongo中,以便进行分页优化。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-13 11:14:28

您可以通过以下简单的聚合来完成它:

代码语言:javascript
复制
db.table.aggregate(
  [
    {
      $group: {
       _id : "$group_id",
       items : { "$push" : "$$ROOT" }
      }
    }
  ]
);

当您希望将数据从聚合输出到新集合时,请使用$out运算符

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39467806

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档