在mongoDb中,如何通过索引删除数组元素{
"_id" : ObjectId("4d1cb5de451600000000497a"),
"name" : "dannie",
"interests" : [
"guitar",
"programming",
"gadgets",
"reading"
] }在上面的示例中,假设上面的文档位于db.people集合中。如何通过它的索引删除兴趣数组的第3个元素?编辑:这是我目前的解决方案:var interests = db.people.findOne({"name":"dannie"}).interests; interests.splice(2,1) db.people.update({"name":"dannie"}, {"$set" : {"interests" : interests}});有更直接的方式吗?
3 回答
皈依舞
TA贡献1851条经验 获得超3个赞
我没有使用未设置(如在接受的答案中),而是通过将字段设置为唯一值(即非NULL)来解决此问题,然后立即提取该值。从异步角度来看更安全一些。这是代码:
var update = {}; var key = "ToBePulled_"+ new Date().toString(); update['feedback.'+index] = key; Venues.update(venueId, {$set: update}); return Venues.update(venueId, {$pull: {feedback: key}});
希望mongo可以通过扩展$ position修饰符来支持$ pull和$ push来解决这个问题。
- 3 回答
- 0 关注
- 1391 浏览
添加回答
举报
0/150
提交
取消