【问题标题】:Mongoose Populate Returning ObjectIds and Empty ArraysMongoose 填充返回的 ObjectId 和空数组
【发布时间】:2021-01-02 17:32:44
【问题描述】:

我有一个集合模型,它有一个包含项目模型数组的项目属性。

const CollectionSchema = new mongoose.Schema({
    title: {
        type: String,
        required: true
    },
    items : [{type : mongoose.Schema.Types.ObjectId, ref: 'Item'}]
});

我尝试填充 items 数组以获取 objectId 的属性,但 items 数组将返回空。 (下面的代码是我如何填充 items 数组。我首先使用 req.body.search 通过 _id 找到了我正在寻找的集合。然后我运行 .populate("items") 以填充 items 数组。我得到的是一个空的 items 数组。)

userRouter.post('/iList', passport.authenticate('jwt', {session: false}), (req, res) => {
    Collection.findById({_id : req.body.search}).populate("items").exec((err, document) => {
        if(err)
            res.json(err)
        else
            res.json({item: document})
    })
});

我知道我的 items 数组不是空的,因为我可以在 mongoDB 上检查它是否已满。 The image of my mongoDB collection with an items array that isn't empty.

奇怪的是,如果我将“集合”放入 .populate 参数中,我的 Items 数组确实会返回内容,但它只返回 ObjectID 而不是实际的对象属性。我很困惑为什么 .populate("items") 不起作用。

【问题讨论】:

    标签: mongodb mongoose mongoose-schema mongoose-populate


    【解决方案1】:

    如果您使用的是 findById,那么为什么要指定 {_id: req.body.search}。如果您的 req.body.search 是一种猫鼬 ObjectId 字符串,那么您可以直接使用 findById(req.body.search) 来代替。您也可以简单地使用投影。 find 调用中的第二个参数是预测

    如果您只尝试获取项目数组,那么为什么不尝试以下查询:-

    Collection.findById(req.body.search, {items: 1}).then((result) => {
       console.log('Items are :-\n', result);
    }, (err) => {
       console.log(err);
    })
    

    1 表示包含,0 表示排除。所以项目将出现在输出中,_id 也是输出中的默认值。如果您想排除 _id,则可以将第二个参数更改为此 -> {items: 1, _id: 0}

    【讨论】:

    • 这确实有效,但结果再次注销了一个 objectID 数组而不是对象属性。我想查看对象属性而不是 objectID。
    【解决方案2】:

    没关系。问题是当我通过 mongoose 推送项目模型时,我忘记执行 items.save() 这意味着 items 数组什么都没有。

    【讨论】:

      猜你喜欢
      • 2016-12-04
      • 1970-01-01
      • 2021-03-03
      • 2017-04-20
      • 2021-08-25
      • 1970-01-01
      • 1970-01-01
      • 2017-10-24
      • 1970-01-01
      相关资源
      最近更新 更多