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

Ребят, вопрос по монге. Была у меня модель Post в которой

были комменты.

const commentsSchema = Schema({
blabla: { type: Number, default: null },
array: [{ name: String, number: String, date: Date, kind: String }]
});
const postShema = Schema({
title: { type: String },
comments:[commentsSchema]
});

Почитав и подумав, я решил эти сущности разбить на 2 разных коллекции:
Post и Comments

И сделал так:

const postShema = Schema({
title: { type: String },
comments:[{ type: Schema.Types.ObjectId, ref: 'Comments' }]
});
const commentsSchema = Schema({
post: {
type: mongoose.Schema.Types.ObjectId,
ref: "Post",
required: true
},
blabla: { type: Number, default: null },
array: [{ name: String, number: String, date: Date }]
});

Но в коллекции Post, у меня еще лежат комменты, по старой архитектуре. Как мне лучше всего удалить их?
Пройтись циклом, удалить и проставить потом в схеме индекс? Спасибо

2 ответов

9 просмотров

Пройтись по всем постам, если внутри есть коменты, то создать их и связать по id. Если данных много, то курсором надо пройтись, чтобы всё разом не вытягивать.

Это называется миграция. Да, тебе надо полностью трансформировать базу. Можешь делать итерациями, можешь агрегацией

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта