170 похожих чатов

Добрый день, ребят! Только начинаю свой путь в MongoDB, но

уже появились трудности. Подскажите пожалуйста, как я могу реализовать следующий запрос на Go к MongoDB:
У меня есть такие данные в MongoDB:
{
"_id": "test",
"name": "hello world",
"homes": {
"v1": {"name": "hello"},
"v2": {"name": "hello"},
"v3": {"name": "hello"},
}
}

Как мне удалить все поля из homes, кроме v1 и v2? Полей может быть много, но мне надо исключить удаление некоторых. По итогу должно получиться такое:
{
"_id": "test",
"name": "hello world",
"homes": {
"v1": {"name": "hello"},
"v2": {"name": "hello"},
}
}

Заранее благодарю!

7 ответов

13 просмотров

насколько я помню, в терминах mongo это называется projection

filter := bson.M{"_id": "test"} update := bson.M{"$unset": bson.M{"homes.v3": "", "homes.v4": ""}} collection.UpdateOne(context.Background(), filter, update)

Андрей-🐍 Автор вопроса
Данил
filter := bson.M{"_id": "test"} update := bson.M{"...

Да, но проблема в том, что таких полей homes.v{N} может быть много и руками я все их вряд ли запишу.

Андрей 🐍
Да, но проблема в том, что таких полей homes.v{N} ...

filter := bson.M{"_id": "test"} update := bson.M{ "$unset": bson.M{ "homes": bson.M{ "$not": bson.M{ "$in": bson.A{"v1", "v2"}, }, }, }, }

Андрей-🐍 Автор вопроса

Пробовал так, но как оказалось, $unset не принимает никаких фильтров 🙃

Андрей 🐍
Пробовал так, но как оказалось, $unset не принимае...

filter := bson.M{"_id": "test"} project := bson.M{ "$project": bson.M{ "name": "$name", "homes": bson.M{ "$filter": bson.M{ "input": bson.M{"$objectToArray": "$homes"}, "as": "item", "cond": bson.M{ "$in": bson.A{"$$item.k", bson.A{"v1", "v2"}}, }, }, }, }, }

Андрей-🐍 Автор вопроса
Данил
filter := bson.M{"_id": "test"} project := bson.M{...

А каким образом мне сделать $unset теперь? bson.M{"$unset": "$homes"}

Похожие вопросы

Обсуждают сегодня

А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
А какие чаты вообще в ходу? Auto aim? И что еше
do you think you're better off alone? А
13
hello friends. Do you know how can I learn getx? I have a software project that I should deliver it up to 5 weeks later and I need to learn firebase too. I will be thankfull
AmirHossein Razavi
15
Доброе время суток! у меня тут иноды закончились. и понял почему по сути кстит, я периодически очищаю постгрес и сентри контайнер: postgres=# DELETE FROM nodestore_node WHER...
Юсиф Насиров
9
Вопрос. Теоретический. Есть список команд. Команды отправляю в обработку некой функции, по очереди. Разные команды могут давать разные результаты после обработки. В зависимос...
Serjone
7
Карта сайта