草庐IT

mongodb - 在 MongoDB 中合并两个 $lookup 集合

coder 2023-11-02 原文

在这里,我尝试从我的 challenge 集合中获取汇总结果,其中包含 challengeusers 并且 challengeusers 具有 user_id,我使用 $lookup 加入用户也是。

当我使用这个查询时,我得到以下输出。

"challenges": [
    {
        "_id": "5b7bf6fd87ec106308d7e3c1",
        "start_date": "2018-08-09T12:40:21.470Z",
        "end_date": "2018-08-05T12:40:21.470Z",
        "challnegedusers": [
            {
                "chalenge_id": "5b7bf6fd87ec106308d7e3c1",
                "user_id": "5b75623db457045e3bb12e0a",
                "status": 1
            },
            {
                "user_id": "5b75643c0a97791bcc9ed64c",
                "status": 1
            },
            {
                "user_id": "5b756144b457045e3bb12e08",
                "status": 1
            }
        ],
        "users": [
            {
                "_id": "5b756144b457045e3bb12e08",
                "first_name": "XYZ"
            },
            {
                "_id": "5b75623db457045e3bb12e0a",
                "first_name": "BAC"
            },
            {
                "_id": "5b75643c0a97791bcc9ed64c",
                "first_name": "YTA"
            }
        ]
    }
]

但我希望challengeusersusers 合并为一个对象。

最重要的是,我想要 challengeusersstatus 以及用户的信息。

预期输出:

"challenges": [
    {
        "_id": "5b7bf6fd87ec106308d7e3c1",
        "start_date": "2018-08-09T12:40:21.470Z",
        "end_date": "2018-08-05T12:40:21.470Z",
        "challnegedusers": [
            {
                "user_id": "5b75623db457045e3bb12e0a",
                "status": 1,
                "first_name": "BAC"
            },
            {
                "user_id": "5b75643c0a97791bcc9ed64c",
                "status": 1,
                "first_name": "YTA"
            },
            {
                "user_id": "5b756144b457045e3bb12e08",
                "status": 1,
                "first_name": "XYZ"
            }
        ]
    }
]

我正在使用的 MongoDB 聚合查询。

        let challenges = await ChallengeModel.aggregate([
            { $match: criteria },
            { $lookup: {
                from: 'challengeusers',
                localField: '_id',
                foreignField: 'challenge_id',
                as: 'challnegedusers'
            } },
            { $lookup: {
                    from: 'appusers',
                    localField: 'challnegedusers.user_id',
                    foreignField: '_id',
                    as: 'users'
            } },
            { $sort: {created_at: -1}}
        ]);

最佳答案

您可以在 mongodb 3.6 中尝试以下聚合

ChallengeModel.aggregate([
  { "$match": criteria },
  { "$lookup": {
    "from": "challengeusers",
    "let": { "challengeusersId": "$_id" },
    "pipeline": [
      { "$match": { "$expr": { "$eq": [ "$challenge_id", "$$challengeusersId" ] } } },
      { "$lookup": {
        "from": "appusers",
        "let": { "user_id": "$user_id" },
        "pipeline": [
          { "$match": { "$expr": { "$eq": [ "$_id", "$$user_id" ] } } },
        ],
        "as": "user"
      }},
      { "$unwind": "$user" },
      { "$addFields": { "first_name": "$user.first_name" }},
      { "$project": { "user": 0 }}
    ],
    "as": "challnegedusers"
  }}
])

用你的方法你可以试试这个

ChallengeModel.aggregate([
  { "$match": criteria },
  { "$lookup": {
    "from": "challengeusers",
    "localField": "_id",
    "foreignField": "challenge_id",
    "as": "challnegedusers"
  }},
  { "$unwind": "challnegedusers" },
  { "$lookup": {
    "from": "appusers",
    "localField": "challnegedusers.user_id",
    "foreignField": "_id",
    "as": "challnegedusers.user"
  }},
  { "$unwind": "challnegedusers.user" },
  { "$addFields": { "challnegedusers.first_name": "$challnegedusers.user.first_name" }},
  { "$sort": { "created_at": -1 }},
  { "$group": {
    "_id": "$_id",
    "start_date": { "$first": "$start_date" }
    "end_date": { "$first": "$end_date" },
    "challnegedusers": { "$push": "$challnegedusers" }
  }}
])

关于mongodb - 在 MongoDB 中合并两个 $lookup 集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51962876/

有关mongodb - 在 MongoDB 中合并两个 $lookup 集合的更多相关文章

  1. ruby-on-rails - 如何在 ruby​​ 中使用两个参数异步运行 exe? - 2

    exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby​​中使用两个参数异步运行exe吗?我已经尝试过ruby​​命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何ruby​​gems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除

  2. ruby - 这两个 Ruby 类初始化定义有什么区别? - 2

    我正在阅读一本关于Ruby的书,作者在编写类初始化定义时使用的形式与他在本书前几节中使用的形式略有不同。它看起来像这样:classTicketattr_accessor:venue,:datedefinitialize(venue,date)self.venue=venueself.date=dateendend在本书的前几节中,它的定义如下:classTicketattr_accessor:venue,:datedefinitialize(venue,date)@venue=venue@date=dateendend在第一个示例中使用setter方法与在第二个示例中使用实例变量之间是

  3. postman——集合——执行集合——测试脚本——pm对象简单示例02 - 2

    //1.验证返回状态码是否是200pm.test("Statuscodeis200",function(){pm.response.to.have.status(200);});//2.验证返回body内是否含有某个值pm.test("Bodymatchesstring",function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");});//3.验证某个返回值是否是100pm.test("Yourtestname",function(){varjsonData=pm.response.json

  4. ruby - 具有两个参数的 block - 2

    我从用户Hirolau那里找到了这段代码:defsum_to_n?(a,n)a.combination(2).find{|x,y|x+y==n}enda=[1,2,3,4,5]sum_to_n?(a,9)#=>[4,5]sum_to_n?(a,11)#=>nil我如何知道何时可以将两个参数发送到预定义方法(如find)?我不清楚,因为有时它不起作用。这是重新定义的东西吗? 最佳答案 如果您查看Enumerable#find的文档,您会发现它只接受一个block参数。您可以将它发送两次的原因是因为Ruby可以方便地让您根据它的“并行赋

  5. ruby - 按数字(从大到大)然后按字母(字母顺序)对对象集合进行排序 - 2

    我正在构建一个小部件来显示奥运会的奖牌数。我有一个“国家”对象的集合,其中每个对象都有一个“名称”属性,以及奖牌计数的“金”、“银”、“铜”。列表应该排序:1.首先是奖牌总数2.如果奖牌相同,按类型分割(金>银>铜,即2金>1金+1银)3.如果奖牌和类型相同,则按字母顺序子排序我正在用ruby​​做这件事,但我想语言并不重要。我确实找到了一个解决方案,但如果感觉必须有更优雅的方法来实现它。这是我做的:使用加权奖牌总数创建一个虚拟属性。因此,如果他们有2个金牌和1个银牌,加权总数将为“3.020100”。1金1银1铜为“3.010101”由于我们希望将奖牌数排序为最高的,因此列表按降序排

  6. arrays - 如何在下面的示例中将两个值数组分组为 n 个值数组? - 2

    我已经有很多两个值数组,例如下面的例子ary=[[1,2],[2,3],[1,3],[4,5],[5,6],[4,7],[7,8],[4,8]]我想把它们分组到[1,2,3],[4,5],[5,6],[4,7,8]因为意思是1和2有关系,2和3有关系,1和3有关系,所以1,2,3都有关系我如何通过ruby​​库或任何算法来做到这一点? 最佳答案 这是基本Bron–Kerboschalgorithm的Ruby实现:classGraphdefinitialize(edges)@edges=edgesenddeffind_maximum_

  7. ruby - 尝试比较两个文本文件,并根据信息创建第三个 - 2

    我有两个文本文件,master.txt和926.txt。如果926.txt中有一行不在master.txt中,我想写入一个新文件notinbook.txt。我写了我能想到的最好的东西,但考虑到我是一个糟糕的/新手程序员,它失败了。这是我的东西g=File.new("notinbook.txt","w")File.open("926.txt","r")do|f|while(line=f.gets)x=line.chompifFile.open("master.txt","w")do|h|endwhile(line=h.gets)ifline.chomp!=xputslineendende

  8. ruby - 在两个 ActiveRecord 类之间合并/复制属性的好方法? - 2

    之前有人问过这个问题,我发现了以下clip关于如何一次设置一个类对象的所有属性,但由于批量分配保护,这在Rails中是不可能的。(例如,您不能Object.attributes={})有没有一种很好的方法可以将一个类的属性合并到另一个类中?object1.attributes=object2.attributes.inject({}){|h,(k,v)|h[k]=vifObjectModel.column_names.include?(k);h}谢谢。 最佳答案 利用assign_attributes使用:without_prote

  9. ruby-on-rails - ruby 中两个哈希之间的变化 - 2

    我有两个具有以下格式的哈希mydetails[x['Id']]=x['Amount']这将包含如下数据hash1={"A"=>"0","B"=>"1","C"=>"0","F"=>"1"}hash2={"A"=>"0","B"=>"3","C"=>"0","E"=>"1"}我期待这样的输出:Differencesinhash:"B,F,E"非常感谢任何帮助。 最佳答案 这个解决方案可能更容易理解:(hash1.keys|hash2.keys).select{|key|hash1[key]!=hash2[key]}Array#|返回2

  10. ruby - 检查 ruby 中的两个范围是否重叠 - 2

    我知道我能做到:(1..30).cover?(2)=>true但是当我尝试对另一个范围执行相同操作时,它总是返回false:(1..30).cover?(2..3)=>false所以我的问题是-是否有任何优雅的方法来比较ruby​​中的两个范围?在我的例子中,我想检查两个日期时间范围是否重叠。提前致谢。 最佳答案 给定范围A的两个范围重叠,当:范围B从范围A开始,范围B在范围A内结束或范围B在范围A之前开始,在范围A之后结束例子:RangeA|-----||-----|Case1|-----|Case2|-|Case1+2|----

随机推荐