Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
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
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.10.2013, 23:37
Помогаю со студенческими работами здесь

Нужна помощь по скрипту/макросу(не знаю как правильно называется)
Вбрела в голову идея. Для форума forum_name сделать автообновление аватара() и не знаю как осуществить эту идею т.к как знаю только html и...

Как сделать, не знаю как это называется :)
Есть CMS где в tpl файле пишутся например {IP} и это соответственно выводит IP Как сделать так же? У меня index.php подключает...

Как это правильно называется
ИмяИнтерфейса название= new КлассКоторыйРеализует(); Это ведь полиформизм в каком то роде? По сути ведь мы создаем объект класса...

Как это правильно называется?
Добрый день, как это правильно называется (хочу почитать про это поподробнее в интернете, но не могу ввиду не знания названия). В...

Задание по программированию: я не знаю темы для ее решения, поэтому точнее назвать не могу :(
Доброго времени суток. Обращаюсь ко всем за помощью - я не могу разобраться в новой теме, на которой моя группа была, а я отсутствовал......


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
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 на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru