Sử dụng phương thức shell findAndModify
phù hợp với nhu cầu của bạn.
Nhưng bạn không thể sử dụng ký tự vị trí $
nhiều lần trong khi chiếu trong MongoDb, vì vậy bạn có thể phải tự theo dõi nó ở phía máy khách.
Sử dụng arrayFilters
để cập nhật tài liệu con lồng nhau sâu, thay vì vị trí tất cả toán tử $[]
.
Dưới đây là một truy vấn đang hoạt động -
var query = {
universe: 'comics'
};
var update = {
$set: {
'saga.$[outer].characters.$[inner].character': 'lobezno',
'saga.$[outer].characters.$[inner].picture': '618035022354.png',
}
};
var fields = {
'saga.characters': 1
};
var updateFilter = {
arrayFilters: [
{
'outer.name': 'x-men'
},
{
'inner.character': 'wolverine'
}
]
};
db.collection.findAndModify({
query,
update,
fields,
arrayFilters: updateFilter.arrayFilters
new: true
});