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

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

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

14 ответов

14 просмотров

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

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

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

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Привет. Я верно понимаю, что в определении класса Монад m — зафиксирован (к тому же поскольку это моноид в категории эндофункторов). Т.е. используя байнд я не могу перемещать...
Arseny
5
еще вопрос, допустим мы создадим char массив из 10 элементов и присвоим ему через сканф 10 символов. и выведем все символы. Хотел спросить последний элемент /0 будет включать...
Anthem
11
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
Карта сайта