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

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

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

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

12 ответов

20 просмотров

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

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, а добавлять удалять запись в таблице? с точки зрения длительности запроса хуже, но ситуации, когда юзер добавит все слова из сборки в избранное практически исключены

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
как быть с принтером? такой подход прокатит?
zamtmn
12
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Привет. Подскажите, как правильно сматчить лист фиксированного размера, чтобы компилятор не говорил мне о неполном паттерне? Допустим что-то такое [x', y'] = sort [x, y]?
Arseny
8
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Карта сайта