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

Парни, никак не могу сообразать структуру БД для следующей задачи:

кидаю события в очереди. Из очередей пишу в БД. Отображаю события в админке для пользователей, нужно отметить как прочитанные те, которые пользователь почитал. Для одного пользователя это все понятно, а как быть если пользователей несколько?

8 ответов

11 просмотров

одно сообщение, множество юзеров что ли?

Дмитрий Щербаков
одно сообщение, множество юзеров что ли?

а лучше вообще сделать 2 таблички сообщения кому показывать сообщения с флагом о прочтении. И у тебя получается гораздо более гибкая архитектура бд

Vadim Ryabov 🔥
а лучше вообще сделать 2 таблички сообщения кому...

по сути то что я написал тоже две таблицы, просто решение немого другое, нраицца

HermanSochi 🌴- Автор вопроса
Vadim Ryabov 🔥
а лучше вообще сделать 2 таблички сообщения кому...

Так в варианте Дмитрий и так их две будет... Или я чего то не догоняю?

HermanSochi 🌴
Так в варианте Дмитрий и так их две будет... Или я...

у него только прочтение, а у меня еще и кому показывать

HermanSochi 🌴- Автор вопроса
Vadim Ryabov 🔥
у него только прочтение, а у меня еще и кому показ...

Ну это я очередями разрулил и разными таблицами в БД, но вижу, что можно упростить )) Спс )

если список новостей для всех одинаковый, хранишь максимальную дату новости, которую прочёл каждый пользователь и считаешь что все более ранние новости он прочёл.

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

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

Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
36
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
18
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
Можно вообще написать: Person fName' lName' age'. Тогда действительно имена полей потребуются лишь в строковом виде, чтобы эти fName' и т.д. достать :-) Но разве для этого нуж...
Михаил
8
generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Hello everyone I am trying to run 4 year old project and I am having this issue anyone can help?
Nitish Garg
11
преобразовать в число или в один тип?
Alexey Kulakov
11
а фасм переживёт включение файла на 47 гигов?
Mixail Frolov
9
Карта сайта