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

Всем привет) есть вопрос, скорее по БД, Есть сущности: Пользователь,

Сборка(слов), Слово
У пользователей может быть несколько сборок, у сборок может быть несколько слов
Пользователь может добавлять в избранное сборки и слова, сколько угодно, хоть все слова в сборке.
Есть еще функционал, пользователь может делиться своими сборками с др пользователями, другие пользователи могут добавлять в избранное сколько угодно слов из чужих сборок(которыми поделились с этими юзерами). Как лучше организовать в таком случае? копировать сборки не вариант, тк слов может быть и 200 в одной сборке.

Интересует момент именно с добавлением в избранное слов из чужих сборок. Как лучше организовать в БД? Мб кто сталкивался с подобным

12 ответов

21 просмотр

Ключ это слово, а значение это массив пользователей у которых это слово есть ?)

Mihail-Grushetckii Автор вопроса
vbbbb
Ключ это слово, а значение это массив пользователе...

Связь сборки и слов - один ко многим. Слово - это сущность, то есть это не просто 1 слово, включает в себя id, слово, его перевод, добавлено ли в избранное

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

Алексей Попов
Никак не могу понять в чём особенность Есть слова...

Точка входа где? Он имеет ввиду. Слово? Начало обьекта

Mihail-Grushetckii Автор вопроса
Алексей Попов
Никак не могу понять в чём особенность Есть слова...

это карточки для запоминания иностранных слов, которая содержит слово на родном языке, ее перевод

Mihail Grushetckii
это карточки для запоминания иностранных слов, кот...

Всё равно не вижу где тут проблемы Есть словарь слов (не важно, хранится перевод в той же таблице, или отдельно). Есть ссылка на слово - на запись в это словаре И дальше ты организуешь хранение этих ссылок как угодно. И связь между пользователем и словом, и связь между пользователем и сборкой - как угодно

Mihail-Grushetckii Автор вопроса

ну вот такой момент, пример: у меня есть 5 сборок по 200 слов (1000слов), я поделился с 5 юзерами, в теории каждый юзер может добавить себе любое слово в избранное(максимум 1000 из моих сборок), получается организую таблицу связей с юзера со словами, получаю 5000 строк. Но если у меня будет 100 сборок(по 200 слов) и я поделюсь с 50 юзерами. Получится 20 000 слов * 50 юзеров = 1млн записей но не только я могу делиться) таких, как я может быть и 1000 человек) не будет ли это нагромождением?

Mihail Grushetckii
ну вот такой момент, пример: у меня есть 5 сборок ...

А сборка может модифицироваться? Если нет, достаточно хранить ссылку на сборку. Если да, то опять же можно (но не нужно) оптимизировать - пока сборки одинаковые храни ссылку на одну сборку у разных пользователей. Как только один из пользователей изменил свою сборку - создавай для неё новую сущность

Mihail-Grushetckii Автор вопроса
Алексей Попов
А сборка может модифицироваться? Если нет, достато...

вопрос больше в другом, как мне кажется) нужен будет функционал - достать все избранные слова (для данного пользователя) из данной сборки, или вообще из всех сборок, то есть нужно хранить информацию о том, какие слова в сборе находятся в избранном у данного пользователя, я поделился с 10 юзерами одной сборкой, но каждый сам решает, какие слова добавить в избранное

Mihail Grushetckii
вопрос больше в другом, как мне кажется) нужен буд...

Так а проблема в чём? Ты не можешь нарисовать структуру бд, или боишься того, что у тебя будет много записей в таблицах? Если второе, то не бойся :)

Mihail-Grushetckii Автор вопроса
Алексей Попов
Так а проблема в чём? Ты не можешь нарисовать стру...

мб есть смысл в таблице связей юзер - слово добавлять только избранные слова? то есть, когда юзер добавляет в избранное не менять флаг true/false, а добавлять удалять запись в таблице? с точки зрения длительности запроса хуже, но ситуации, когда юзер добавит все слова из сборки в избранное практически исключены

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: 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
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
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
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта