![](/img/trans.png)
[英]delete object from document array in mongodb collection using mongoose
[英]Delete a key from a MongoDB document using Mongoose
我正在使用Mongoose库通过 node.js 访问 MongoDB
有没有办法从文档中删除密钥? 即不只是将值设置为空,而是将其删除?
User.findOne({}, function(err, user){
//correctly sets the key to null... but it's still present in the document
user.key_to_delete = null;
// doesn't seem to have any effect
delete user.key_to_delete;
user.save();
});
在早期版本中,您需要删除 node-mongodb-native 驱动程序。 每个模型都有一个集合对象,其中包含 node-mongodb-native 提供的所有方法。 因此,您可以通过以下方式执行相关操作:
User.collection.update({_id: user._id}, {$unset: {field: 1 }});
从 2.0 版开始,您可以执行以下操作:
User.update({_id: user._id}, {$unset: {field: 1 }}, callback);
从 2.4 版开始,如果您已经有一个模型实例,您可以执行以下操作:
doc.field = undefined;
doc.save(callback);
你会想要这样做:
User.findOne({}, function(err, user){
user.key_to_delete = undefined;
user.save();
});
我使用猫鼬并使用上述任何功能满足我的要求。 该函数编译无错误,但该字段仍将保留。
user.set('key_to_delete', undefined, {strict: false} );
帮我解决了这个问题。
Mongoose 文档不是一个普通的 javascript 对象,这就是为什么您不能使用 delete 运算符。(或从 'lodash' 库中unset
)。
您的选择是设置 doc.path = null || undefined 或使用 Document.toObject() 方法将 mongoose doc 转换为普通对象,然后照常使用它。 在 mongoose api-ref 中阅读更多内容: http : //mongoosejs.com/docs/api.html#document_Document-toObject
示例如下所示:
User.findById(id, function(err, user) {
if (err) return next(err);
let userObject = user.toObject();
// userObject is plain object
});
这可能是一个附带问题,例如使用
function (user)
而不是
function(err, user)
对于 find 的回调? 只是想帮助解决这个问题,因为我已经有了这个案例。
尝试:
User.findOne({}, function(err, user){
// user.key_to_delete = null; X
`user.key_to_delete = undefined;`
delete user.key_to_delete;
user.save();
});
所有这些答案的问题在于它们适用于一个领域。 例如,假设我想从我的文档中删除所有字段,如果它们是空字符串""
。 首先,您应该检查字段是否为空字符串将其放入$unset
:
function unsetEmptyFields(updateData) {
const $unset = {};
Object.keys(updatedData).forEach((key) => {
if (!updatedData[key]) {
$unset[key] = 1;
delete updatedData[key];
}
});
updatedData.$unset = $unset;
if (isEmpty(updatedData.$unset)) { delete updatedData.$unset; }
return updatedData;
}
function updateUserModel(data){
const updatedData = UnsetEmptyFiled(data);
const Id = "";
User.findOneAndUpdate(
{ _id: Id },
updatedData, { new: true },
);
}
如果你想从集合中删除一个键,试试这个方法。
db.getCollection('myDatabaseTestCollectionName').update({"FieldToDelete": {$exists: true}}, {$unset:{"FieldToDelete":1}}, false, true);
我相信,如果您希望将特定字段删除到集合中,您应该这样做:
User.remove ({ key_to_delete: req.params.user.key_to_delete});
您可以使用删除 user._doc.key
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.