Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Проектирование БД для гостевой, ну или почти для гоствевой 
:(
    Опции темы
krulik
Дата 24.4.2006, 11:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 132
Регистрация: 14.1.2006
Где: Украина, Житомир

Репутация: нет
Всего: 4



Суть вопроса вот в чем. Есть гостевая. Сделал так чтобы юзеру  (в моем случае для группы админов) выводилось сообщении о новых собщениях с момента последнего визита. Так вот вопрос вот какой. Как сделать так чтобы после просмотра опредленных сообщений они отмечались как прочтенные (только для пользователя который просматривал) . Еслибы был один пользователь то вопросов бы не было, но так как юзеров много то как организовать подобное придумать не могу.

ЗЫ: если вопрос не понятен то спрашивайте. Попробую объяснить. 
--------------------
Каждый день несет в себе частицу вечности (Паоло Коэльо)Если вам плюют в спину, значит вы в переди! (Конфуций)Все, что имеет форму, может исчезнуть в одно мгновение (Харуки Мураками)
PM MAIL ICQ   Вверх
chief39
Дата 24.4.2006, 14:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Таблица, указывающая, что ДАННЫЙ юзер УЖЕ просматривл ДАННОЕ сообщение.
Код
create table seen(
    user_id integer not null,
    message_id not null,
    primary key(user_id, message_id)
)

Изначально - пуста. Когда юзер X просматривает сообщение Y в таблицу заносится запись (X,Y).
Привыборке непросмотренных сообщений - делай not in по месседжам, зарегистрированным в данной таблице (то есть отсекай все мессаги, которые тут зарегистрированы).

Чтоб табличка не выросла до небес - можно сделать так(предполагается что у месседжа есть дата создания):
в табличку user(или как она у тебя называется) добавь поле timestamp.
В этом поле будет храниться дата, ДО КОТОРОЙ ВСЕ МЕССАГИ ПРОСМОТРЕНЫ.
Если в момент просмотра мессаги НЕТ НЕПРОСМОТРЕННЫХ, НО СОЗДАННЫХ РАНЕЕ - тогда дату создания текущей мессаги переноси в user timestamp. Это означает что все более старые мессаги просмотрены. Соответственно ,все записи из таблицы seen для старых мессаг можно удалить.

Тогда при выборке непросмотренных мессаг надо будет выбрать ВСЕ, КОТОРЫЕ СОЗДАНЫ ПОЗЖЕ timestamp'a текущего юзера и отфильтровать те, которые зарегистрированы в табличке seen. Всё оставшееся - будет непросмотренными мессагами smile

Это не окончательный вариант - если решишь реализовать - пиши. 
Если будут траблы с логикой добавления/удаления/селектов - пиши - набросаю.

Добавлено @ 14:34 
ЗЫ: Если всё гораздо проще(вход юзера на гостевую во время X автоматически считает что мессаги, созданные до этого времени - прочтены им) - тогда можно обойтись одним timestamp'ом у юзера. Но мне кажется, что ты имел в виду первый вариант. ;)  


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
Vit
Дата 24.4.2006, 15:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



Открываем любой букварь по базам данных, читаем главу "Отношение многие-ко-многим" 


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
kivan
Дата 4.5.2006, 14:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 111
Регистрация: 17.10.2005

Репутация: нет
Всего: нет



Цитата(Vit @  24.4.2006,  15:22 Найти цитируемый пост)
Открываем любой букварь по базам данных, читаем главу "Отношение многие-ко-многим"  

 к примеру: 
Этот!

Там, все интересующие вас вопросы, подробно расписаны.
Качаем и читаем...
толковая книжонца, советую прочесть!!!  

Это сообщение отредактировал(а) kivan - 4.5.2006, 14:50
--------------------
#----------------------------------------------------------#A little knowledge is a dangerous thing...!!!senatum.blogspot.com
PM MAIL WWW ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1070 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.