Вот структура массива
contact: {
phone: [
{
number: "+1786543589455",
place: "New Jersey",
createdAt: ""
}
{
number: "+1986543589455",
place: "Houston",
createdAt: ""
}
]
}
Здесь я знаю только mongo id ( _id
) и номер телефона ( +1786543589455
), и мне нужно удалить весь соответствующий элемент массива из документа. т.е. элемент с нулевым индексом в массиве телефонов совпадает с номером телефона, и необходимо удалить соответствующий элемент массива.
contact: {
phone: [
{
number: "+1986543589455",
place: "Houston",
createdAt: ""
}
]
}
Я пробовал использовать следующий метод обновления
collection.update(
{ _id: id, 'contact.phone': '+1786543589455' },
{ $unset: { 'contact.phone.$.number': '+1786543589455'} }
);
Но он удаляет number: +1786543589455
из внутреннего массива объект, а не нулевой индексированный элемент в массиве телефона. Пробовал pull
тоже безуспешно.
Как удалить элемент массива в mongodb?
{ $pull: { 'contact.phone.$': { 'contact.phone.$.number': '+1786543589455' } } }
и{ $pull: { 'contact.phone': { 'contact.phone.$.number': '+1786543589455' } } }
безуспешно. Не понимает здесь работы позиционных операторов?