Форум программистов, компьютерный форум, киберфорум
MongoDB
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
Модератор
 Аватар для long399
2882 / 1836 / 933
Регистрация: 16.10.2013
Сообщений: 5,240
Записей в блоге: 15

Удаление определенного атрибута в массиве вложенных документов

20.01.2022, 10:22. Показов 1853. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.

Имеется коллекция record, хранящая архивные дела. Вот её упрощенная структура (опустил большинство атрибутов):
JSON
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
{
  "_id": 1,
  "tomes": [
    {
      "number":1,
      "archive_number":1
    },
    {
      "number":2,
      "archive_number":1
    }
  ]
}
{
    "_id": 2,
  "tomes": [
    {
      "number":1,
      "archive_number":1
    },
    {
      "number":2,
      "archive_number":1
    },
    {
      "number":3,
      "archive_number":1
    }
  ]
}
Мне нужно для всех документов коллекции record у каждого из вложенных документов массива tomes удалить атрибут archive_number.

После удаления структура должна принять следующий вид:
JSON
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
{
  "_id": 1,
  "tomes": [
    {
      "number":1,
    },
    {
      "number":2,
    }
  ]
}
{
    "_id": 2,
  "tomes": [
    {
      "number":1,
    },
    {
      "number":2,
    },
    {
      "number":3,
    }
  ]
}
Смог написать такой запрос:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
db.record.update(
  {
    "tomes": {
      $elemMatch:{
        "archive_number":{$exists:true}
      }
    }
  },
  {
    $unset: {
      "tomes.$.archive_number":1
    }
  },
  false, true
)
Но этот запрос выполняет для каждого архивного дела удаление атрибута archive_number лишь в одном томе. Т.е. после запуска мы увидим такую картину:
JSON
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
{
  "_id": 1,
  "tomes": [
    {
      "number":1,
    },
    {
      "number":2,
      "archive_number":1
    }
  ]
}
{
    "_id": 2,
  "tomes": [
    {
      "number":1,
    },
    {
      "number":2,
      "archive_number":1
    },
    {
      "number":3,
      "archive_number":1
    }
  ]
}
Подскажите, пожалуйста, как сделать удаление во всех томах? Не знаю как поправить запрос, а голова уже не соображает.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.01.2022, 10:22
Ответы с готовыми решениями:

Сортировка и обеовление вложенных документов
Здравствуйте! Переписывал сайт под монгу, сделал что мог осталось 2 вопроса которые никак не могу решить. 1. Есть документ, в нем...

Копирование вложенных документов из excel в word
Добрый день. Имеется задача - 1) Документы word содержат таблицы. В ячейках таблиц есть вложенные файлы - например TestData.doc,...

Вывод определенного атрибута
Здравствуйте, новичок в php и xml, не получается вывести конкретный атрибут( под id="100498817"), пытался вывести с помощью if...

1
Модератор
 Аватар для long399
2882 / 1836 / 933
Регистрация: 16.10.2013
Сообщений: 5,240
Записей в блоге: 15
05.03.2022, 11:56  [ТС]
Лучший ответ Сообщение было отмечено long399 как решение

Решение

Некоторое время назад нашёл решение своего вопроса, но в теме забыл отписаться об этом. Прикладываю запрос, который помог мне достичь нужного результата:

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
db.record.update(
  {
    "tomes":{
      $elemMatch:{
        "archive_number":{
          $exists:true
        }
      }
    }
  },
  {
    $unset:{
      "tomes.$[].archive_number":1
    }
  },
  {
    multi:true
  }
)
Следует отметить, что оператор $[] не работал на версии mongodb 3.2.22 или 3.4.24 (точно не помню какая стояла). Учитывайте, что этот запрос не будет правильно работать на какой-то из этих версий mongodb. Возможно, и на обеих версиях не будет.

Сейчас я себе поставил версию 4.2.18. На ней всё работает.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.03.2022, 11:56
Помогаю со студенческими работами здесь

Отображение вложенных документов Word в режиме структуры
Всем доброго дня. Возникла необходимость объединять в один файл word (naprav_0.doc) 3 файла (~naprav~1.doc, ~naprav~2.doc, ~naprav~3.doc)....

Вывод атрибута value определенного размера
<input id="ciField" name="field" type="Text" size=30 value="0" width="300px"> Хочется больше и жирнее ^^ Как на LED...

Xml вывести с определенного атрибута
Здравствуйте! Как получить информацию из определенного id атрибута например: вывести все name из note id="2" ...

Как сделать скриншот определенного атрибута страницы?
Как программно сделать скриншот атрибута "img", где находится картика?(картику по юрл скачать нельзя, так как доступ ограничен)

Поиск файлов определенного формата в папке, и во всех вложенных
Всем привет. Такая задача. Имеетса папка, в которой находятса многа папок. И в этих папках есть документы одного формата. Надо сделать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru