[英]Referring to ObjectIDs directly in MongoDB works, but not in Mongoose
第一个代码段达到了预期的效果:
//in mongodb console:
db.collection.update({"username":"name"}, {$pull : { "task" : { "_id" : ObjectId("55280205702c316b6d79c89c")}}})
但是,用猫鼬编写的第二个(看似等效)代码片段没有:
//in Mongoose:
var taskID = "55280205702c316b6d79c88c"
var pull = { $pull : {}};
var idObj = {};
idObj["_id"] = taskID;
pull.$pull["task"] = idObj;
collectionModel.update({"username": "name"}, pull) //fails to work since taskID just shows up as a literal string 55280205702c316b6d79c88c instead of ObjectId("55280205702c316b6d79c88c")
我尝试过的其他方法:
var taskID
等于字符串'ObjectId(\\"55280205702c316b6d79c88c\\")'
var taskID
等于mongoose.Types.ObjectId("55280205702c316b6d79c88c")
如何在Mongoose的以前的代码片段中实现效果?
导入ObjectId类型并在查询中使用它:
var ObjectId = require('mongoose').Types.ObjectId;
idObj["_id"] = new ObjectId("55280205702c316b6d79c88c");
在mongodb shell中执行$pull
操作并在具有相同ObjectId的Mongoose中尝试了相同的更新操作后,此操作不起作用,因为带有"_id": ObjectId("55280205702c316b6d79c88c")
的任务数组对象元素"_id": ObjectId("55280205702c316b6d79c88c")
已由先前的操作删除。 mongodb shell操作。
尝试首先从Mongoose运行相同的查询,但是使用已转换为ObjectId的现有任务ID并有所不同。 您可以将扩展名添加到String对象,如下所示:
String.prototype.toObjectId = function() {
var ObjectId = (require("mongoose").Types.ObjectId);
return new ObjectId(this.toString());
};
var taskID = "55280205702c316b6d79c88d".toObjectId(); // a different _id
collectionModel.update(
{ "username": "name" },
{ "$pull" : { "task": { "_id": taskID } } },
function (err, result) {
console.log(result);
}
);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.