迈克雷(MichaelRay) 2022-03-15 17:19
浏览 4

子文档是数组怎么做$lookup呢

{
    "_id": ObjectId("61ea7e9da9d1ce8814002d17"),
    "name": "雷",
    "age": 39,
    "products": [
        {
            "name": "测试产品1",
            "size": [
                ObjectId("622f0f71a9d1ce74b4001512"),
                ObjectId("622f0f8aa9d1ce74b4001513")
            ]
        },
        {
            "name": "测试产品2",
            "size": [
                ObjectId("622f0f71a9d1ce74b4001512")
            ]
        }
    ]
}

上面是student

 

 

product_size

 

{
    "_id": ObjectId("622f0f71a9d1ce74b4001512"),
    "name": "15寸"
}


{
    "_id": ObjectId("622f0f8aa9d1ce74b4001513"),
    "name": "17寸"
}
  • 写回答

1条回答 默认 最新

  • 迈克雷(MichaelRay) 2022-03-17 17:53
    关注
    
    
    ```javascript
    
    db.student3.aggregate([
        {
            $lookup: 
            {
                from: 'products2', // 右集合
                let: {
                    student_products: "$product_ids",
                    
                },
                pipeline: [
                    {
                        // 应该循环匹配
                        $match: {
                            $expr: 
                            {
                                $in: ["$_id", "$$student_products"]
                            }
                        }
                    },
                    {
                        // 子文档使用lookup
                        $lookup: {
                            "from": "test_size",
                            "localField": "size",
                            "foreignField": "_id",
                            "as": "size"
                        }
                    },
                    {
                        $project: {
                            _id: 0
                        }
                    }
                ],
                as: 'order_products' // 新生成字段(类型array)
            },
            
        },
        {
            $project: {
                product_ids: 0
            }
        }
    ])
    
    
    
    
    

    ```

    评论

报告相同问题?

问题事件

  • 创建了问题 3月15日

悬赏问题

  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法