在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 關注
- 1421 瀏覽
添加回答
舉報
0/150
提交
取消