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

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

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

14 ответов

33 просмотра

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

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

Семен-Марциновський Автор вопроса
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 не поддерживает полиморфные связи)

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
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
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно 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
Карта сайта