Всем привет, можете подсказать, пожалуйста такой вопрос. Я хочу сделать

для себя сайт по книгам, я создал коллекцию с жанрами (Id, name). Хочу в документ с книгой добавлять массив жанров, каким образом описать его? Какие типы? Что хранить? (Только id или полный объект) Как потом получать сджоиненные значения? (Работал только с mysql и postgres, впервые с mongodb работаю)

13 ответов

12 просмотров

Сделайте коллекцию жанров, храните ссылки (_id)

Николай- Автор вопроса
Дмитрий Кузнецов
Сделайте коллекцию жанров, храните ссылки (_id)

то есть я в массив добавляю просто objId нужных жанров?

Николай- Автор вопроса
Дмитрий Кузнецов
Да

А как получить при выборке полный объект?

Джойны в монге не такие быстрые как в реляционках. Я бы посоветовал жанры хранить сразу в документах книг

yopp 💉💉
На чём основывается это утверждение?

На личном опыте. В моем случае переджойнить 100 млн с 200 млн записей получилось на 40% медленнее, чем в постгресе

Viktar
На личном опыте. В моем случае переджойнить 100 мл...

а можете сказать в чем потребность джойнить 100кк с 200кк доков? интересен кейс

Всё зависит от того как вы хотите потом эти жанры использовать

Николай- Автор вопроса
yopp 💉💉
Всё зависит от того как вы хотите потом эти жанры ...

В документ книги добавлять массив жанров, выводить при выдаче на клиент наименования жанров, также организовать фильтры по ним

Viktar
Люди и адреса. Две разных коллекции

Даже в специфичной вертике так редко джойнят. Обычно для этих целей с такими объемами создаётся отдельная материализованные таблица, куда данные джобами/триггерами заливаются/обновляются инкрементально. Так скорость доступа до данных гораздо лучше, хоть и требуется больше места

WolderVsrat
Даже в специфичной вертике так редко джойнят. Обыч...

Да. Так сделаю. Это был просто эксперимент

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

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

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Карта сайта