首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >$lookup返回所有数据

$lookup返回所有数据
EN

Stack Overflow用户
提问于 2020-03-06 14:47:17
回答 1查看 49关注 0票数 0

我在下面的场景中:我有两个集合,medicosclinicas。医学与临床有关的是其ObjectId。我只想弄到里面有医生的临床医生。所以我有个密码:

代码语言:javascript
运行
复制
Clinicas.aggregate([
            $group: {
                _id: {
                    nome: "$nome"
                }

            }
        },
        {
            $lookup: {
                from: "medicos",
                localField: "medico.medicoId",
                foreignField: "_id._id",
                as: 'result'
            }
        },

但有些地方不对劲:它返回as中的所有医疗人员:“结果”。例如:我在医疗收集中有4个文档,在临床集合中有两个文档。第一个诊所有2个医生,第二个医生有1个,但是as:“结果”数组为我带来了两个临床集合的所有医疗文档,正如你所看到的。

这有两个医生

型医疗器械

代码语言:javascript
运行
复制
const mongoose = require('mongoose');
const Schema = mongoose.Schema;

const MedicoSchema = new Schema({
  //cod_medico:{type:Integer},
  nome:{
    type: String,
    required: true,
    maxlength: 80  
  },
},
);

module.exports = mongoose.model('medicos', MedicoSchema);

在数据库中,集合名也是“medicos”。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-03-06 18:39:55

错误在组中,您首先要更改id,然后使用新id连接数据。尝试更改管道的顺序,或移除组阶段。如下所示:

代码语言:javascript
运行
复制
db.clinica.aggregate([
    {
        $lookup: {
            from: "medicos",
            localField: "medico.medicoId",
            foreignField: "_id",
            as: 'result'
        }
    },

])

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

https://stackoverflow.com/questions/60566429

复制
相关文章

相似问题

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