【问题标题】:Add field not in schema with mongoose使用猫鼬添加不在模式中的字段
【发布时间】:2018-11-28 19:04:48
【问题描述】:

我正在尝试向文档添加新字段,但这不起作用:

创建我的 UserModel 原型:

model = require("../models/user")
UserModel.prototype.findOneAndUpdate = function(query, params, cb) {
    model.findOneAndUpdate(query, params, { returnNewDocument: true, new: true }, function(err, data) {
        if (!err) {
            cb(false, data);
        } else {
            cb(err, false);
        }
    });
};

然后调用它

userFunc = require("../../model_functions/user")

userFunc.findOneAndUpdate({
    "email.value": userEmail
}, {
    $set: {"wat":"tf"}
},
function (err, updatedUser) {
    //This logs the updated user just fine, but the new field is missing
        console.log(updatedUser);
                  ...
});

这会成功更新任何存在的字段,但不会添加任何新字段。

【问题讨论】:

  • 架构中添加了新字段?
  • wat 是否在用户的架构中定义? Mongoose 旨在强制执行架构,包括丢弃不与其对齐的属性。
  • 不,但这不应该是添加它的必要条件,或者至少我是这么认为的。它是一个临时字段。
  • 另外,如果我直接在 mongo 控制台中进行操作,它会起作用,它会添加新字段。
  • @LuisEgan 这对猫鼬很重要。 ODM 旨在强制执行您定义的模式,验证每个属性是否属于并丢弃不属于的那些。如果您希望文档是模式和无模式的混合,您可以将属性定义为Mixed type,然后可以包含所需的任何种类的信息。否则,如果您不希望像这样强制执行架构,那么 Mongoose 可能不适合您的用例。

标签: javascript node.js mongodb mongoose mongodb-query


【解决方案1】:

引用JonathanLonowski

ODM 旨在强制执行您定义的架构,验证每个属性是否属于并丢弃不属于的那些。

因此,为了使用 mongoose 更新字段,该字段必须存在于模型的架构中。

【讨论】:

【解决方案2】:

您可以使用选项 { strict: false } 在架构中添加和删除字段

选项:严格

strict 选项(默认启用)确保传递给 我们的模式中未指定的模型构造函数没有得到 保存到数据库中。

var thingSchema = new Schema({..}, { strict: false });

您也可以在更新查询中执行此操作

Model.findOneAndUpdate(
  query,  //filter
  update, //data to update
  { //options
    returnNewDocument: true,
    new: true,
    strict: false
  }
)

您可以查看文档here

【讨论】:

  • 好的,但我想补充一点,第一个对我不起作用,只需将其添加到 findOneAndUpdate() 即可。
  • 如果您运行创建或插入查询,它确实有效...这里的主要动机是让人们知道选项 strict 以及如果字段不存在人们可以添加和删除字段的事实在猫鼬模式中
  • 对我来说,首先将strict 设置为false 的选项适用于插入和更新。
【解决方案3】:

您可以使用 .add 在模式用户中添加新字段

require('mongoose').model('User').schema.add({fullName: String});

谢谢。-

【讨论】:

  • 它对我有用。我不需要在模型严格性上妥协。
  • 在这种情况下,如何检查schema中是否存在该字段,如果不存在则添加?
猜你喜欢
  • 2023-04-07
  • 1970-01-01
  • 2020-11-08
  • 2019-05-23
  • 2017-09-14
  • 2021-09-22
  • 1970-01-01
相关资源
最近更新 更多