|
0 / 0 / 0
Регистрация: 26.05.2011
Сообщений: 4
|
|
Отметка о прочтённом сообщении. Не знаю как это называется правильно, поэтому не могу написать правильный заголовок20.10.2013, 16:13. Показов 1215. Ответов 5
Метки нет (Все метки)
Здравствуйте! Как видно из заголовка - я не могу правильно написать вопрос. А это, возможно. привело бы меня к решению в гугле за секунды.
Хочу понять, как в БД организуются "множественные привязки". Итак. Есть система, в которой заведено N пользователей. В системе появляется сообщение. Сообщение в статусе "не прочитано" для каждого пользователя. Один из них прочитал сообщение. Как сохранить состояние "прочитано" для конкретного пользователя? В случае, есть N=1, то всё просто. Когда N>1, я вижу 2 решения: 1) завести табличку message_readed с полями message_id, user_id, валить туда всё в кучу и селектить каждый раз для каждого сообщения 2) для каждого юзера в табличке messages завести поле readed_M, где M будет ИД юзера. При создании нового пользователя добавлять ещё одно поле. Я не силён в администрировании БД, но оба варианта кажутся мне дико кривыми. Красивое решение - для каждого сообщения иметь возможность привязать произвольное количество юзеров. Для уточнения статуса сообщения проверять, есть ли привзяка к юзеру. Говоря "привязать", "привязка" я не знаю, что я имею ввиду. Собственно, вопрос: как такие вещи делаются "красиво"?
0
|
|
| 20.10.2013, 16:13 | |
|
Ответы с готовыми решениями:
5
Вернуть строку в режим ввода (не знаю как это правильно называется) Как сделать ограничение на перемещение? Или я не знаю как называется это правильно. (См. внутри) |
|
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
|
|
| 20.10.2013, 18:07 | |
|
Отношение многие-к-многим. Заводится промежуточная таблица с внешними ключами к юзерам и сообщениям. Сам факт наличия такой записи для конкретных юзера и сообщения - сообщение прочитано. Нет записи - сообщение не прочитано. Можно, например, туда еще и дату втулить - когда прочитано
0
|
|
|
0 / 0 / 0
Регистрация: 26.05.2011
Сообщений: 4
|
|
| 20.10.2013, 19:32 [ТС] | |
|
0
|
|
|
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
|
|
| 20.10.2013, 19:39 | |
|
В общем-то первый, только не нужно сразу по созданию сообщения туда все валить, а по мере их прочтения юзерами. Второй вариант из разряда..., короче не айс
0
|
|
|
0 / 0 / 0
Регистрация: 26.05.2011
Сообщений: 4
|
||
| 20.10.2013, 20:16 [ТС] | ||
0
|
||
|
363 / 334 / 38
Регистрация: 29.03.2011
Сообщений: 838
|
|
| 20.10.2013, 23:37 | |
|
uscr, у себя на сайте поступаю почти аналогично описанному Аватар-ом, только наоборот:
в табличку msg_usrs (many-to-many) сразу закидываю кому надо данное сообщение прочитать. У каждого юзера по таймеру ajax-ом тыкается, нет ли чего с его id-ом, если есть - вылезает сбоку "вам сообщение". По мере прочитывания записи удаляются. Это позволяет не сильно захламалять табличку. Если нет нужды хранить точное время прочтения - вполне себе вариант.
0
|
|
| 20.10.2013, 23:37 | |
|
Помогаю со студенческими работами здесь
6
Нужна помощь по скрипту/макросу(не знаю как правильно называется) Как сделать, не знаю как это называется :)
Задание по программированию: я не знаю темы для ее решения, поэтому точнее назвать не могу :( Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога
Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
|
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|