我正在使用最新的 meteor 包开发 meteor 应用程序。我想在 mongo 文档数组中重新定位一个项目。为此,我将其 $pull
从数组中取出,然后根据 mongoDB documentation 在特定的 index
位置 $push
它.
MyCollection.update({_id: my_doc.id},
{
$push:
{
my_array:
{
$each:[my_item.id],
$position:index
}
}
}
)
Meteor/Mongo 抛出以下错误:
update failed: MongoError: Can't canonicalize query: BadValue unknown top level operator: $each
我首先实现了这个客户端。由于 minimongo 的限制,我认为它不起作用。
我写了一个方法来处理这个服务器端,但我最终得到了同样的错误。
这个请求有什么问题,meteor可以处理$each操作符吗?
EDIT :我尝试将其直接插入到 robomongo 中,并且成功了。 Mongo 版本,当输入 db.version()
返回 2.6.7
*EDIT2 :我没想到它,所以我之前没有检查:更新工作,无论是 $pull
和 $push
。但是,即使实际更新了数据,我仍然会收到错误消息。
*EDIT : 这是一些示例数据:
{
"_id" : "oSNrpgAAu8BuznvD6",
"name" : "tynhjderjye",
"description" : "",
"notes" : "",
"display_notes" : false,
"keywords" : [
""
],
"owner" : "mA5Y7LBCoRyeSDkaG",
"createdAt" : ISODate("2015-10-27T13:59:06.083Z"),
"createdBy" : "C3i9oj4eapyttHZj6",
"contributors" : [
"C3i9oj4eapyttHZj6"
],
"medias" : [
"TcFqermNY4y5cjBG3",
"dbkNN2rxXJXth8urw",
"jML4JKkRoKxx8sLwu",
"LEWYsnPrXRSH6MPkX"
],
"modifiedAt" : ISODate("2015-11-17T09:35:50.303Z"),
"modifiedBy" : "C3i9oj4eapyttHZj6",
"chunks" : [
"qCCHKJDbdTLEFR5Yt",
"ySiM7dcxvduEM2npj",
"5q46vqrmYttscitiK"
],
"trashed" : ISODate("2015-11-17T09:35:50.303Z")
}
chunks
是数组 my_array
,我在其中将 my_item.id
拉到 index
最佳答案
如果你使用 new Mongo.Collection('col')
创建一个 Meteor Collection,你会得到一个不是原生 Node MongoDriver 的 Minimongo 实例,对吧?
所以有些方法不起作用或不完全支持.. 比如 collection.aggregate
但是您可以通过 Col.rawCollection()
轻松访问 native 驱动程序并直接在 native 实例上执行查询。 当然, native 实例只能在服务器上访问。
所以你有几种方法可以做你想做的事,例如你可以先获取数组,然后按照你想要的方式使用它,然后
$set: {my_array: sortedArray }
我个人更喜欢这种方式,因为您只需要执行一次更新操作而不是两次 ($pull
& $push at $position
)
但是如果你想以 $push at $position 的方式来做这件事.. 只需使用 native 驱动程序就可以了
var col = Collection.rawCollection();
var result = Meteor.wrapAsync(col.update.bind(col)(
/* update query goes here */
);
注意:由于 Meteor 同步样式,您需要 Meteor.wrapAsync,您也可以不使用它。 Collection.rawCollection().update(...)
关于mongodb - meteor mongo 驱动程序可以处理 $each 和 $position 运算符吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34269850/