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

Ребят привет, еще раз задам вопрос, как бы вы сделали

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

14 ответов

30 просмотров

красивее будет конечно разделить тогда управление будет легче

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

Семен-Марциновський Автор вопроса
Andrei Ilinskii
Разделить. И скорее всего отдельно завести сущност...

Еще вопрос, получается делать два запроса на получение из той и из той таблицы, чтоб получить все чаты хуже, чем создать третью, в которой будут все?

Семен Марциновський
Еще вопрос, получается делать два запроса на получ...

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

Семен-Марциновський Автор вопроса
Andrei Ilinskii
В зависимости от того какие операции у тебя происх...

Думал про это, можно было бы добавить какую-то колонку типа order_number, но это уже похоже на затычку, причем довольно страшную

Семен Марциновський
Думал про это, можно было бы добавить какую-то кол...

А толку? - Вот у тебя две таблицы. В них есть order number. Ты по ним отсортировал данные. И тебе нужно объединить результаты с учётом сортировки, это не по индексу будет опять же =) Лучше отдельная табличка, имхо.

Семен-Марциновський Автор вопроса
Andrei Ilinskii
А толку? - Вот у тебя две таблицы. В них есть orde...

Сорян, забыл спросить, последний вопрос, есть какая-то особая технология для создания смежной табл. или она как обычная табл.? Просто закидывать в нее данные когда эдитишь первые две?

Семен-Марциновський Автор вопроса

По юзерам many_to_many? users_chats - что-то типо этого?

Семен Марциновський
По юзерам many_to_many? users_chats - что-то типо ...

Как уже много раз повторяли - всё зависит от того как вы с этим работаете. Для типичного чата, скорее всего, это будет хорошее решение.

Andrei Ilinskii
А толку? - Вот у тебя две таблицы. В них есть orde...

А почему это будет не по индексу? При чём-то вроде CREATE VIEW all_chats AS SELECT ... FROM table1 UNION ALL SELECT ... FROM table2 запрос вроде SELECT * FROM all_chats WHERE user_id = $1 ORDER BY chat_name вполне себе будет использовать индексы (если они есть) как для выборки, так и для сортировки, нет? Или речь о какой-то другой ситуации?

Andrei Ilinskii
VIEW - плохое решение для чатов, имхо.

View здесь для демонстрации (записать его текст в запрос как WITH или подзапрос — и будет то же самое). Почему view — плохое решение, кстати?

Семен-Марциновський Автор вопроса
Yaroslav Schekin
А почему это будет не по индексу? При чём-то вроде...

Уже поздно наверное, но спрошу, а какое решение в данном случае предлагаешь ты? У меня просто orm не поддерживает полиморфные связи)

Семен Марциновський
Уже поздно наверное, но спрошу, а какое решение в ...

Так я же не знаю, какие точно требования... особенно с учётом "неестественных" ограничений вроде: > У меня просто orm не поддерживает полиморфные связи)

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

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

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Кстати, что за тип булеана, который в памяти как 00 для фолса и 01 для тру отображается? Однобайтовый
Serjone
8
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
Карта сайта