Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757
Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737 Форумы портала PHP.SU :: Как отменить темы прочитанными?
Покинул форум
Сообщений всего: 32
Дата рег-ции: Июнь 2011
Помог: 0 раз(а)
Пишу свой форум на php и mysql. Каким образом можно сделать так, что если пользователь зашел в форум, тему, ее иконка менялась на прочитано, как на всех современных форумах?Понятия не имею что записывать и что проверять так сказать.
OrmaJever
Отправлено: 13 Июня, 2011 - 17:27:18
Активный участник
Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010 Откуда: Чернигов
Помог: 299 раз(а)
смотря ка у вас бд устроена.
Берём ид темы и выбираем один последний коментарий и смотрим кто автор.
----- Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
scray
Отправлено: 13 Июня, 2011 - 22:16:16
Гость
Покинул форум
Сообщений всего: 68
Дата рег-ции: Апр. 2009
Помог: 0 раз(а)
Можешь в сессии или в куках хранить массив, в который будешь складывать ID посещенных тем. При первом входе все темы, созданные за последний месяц (например) будут не прочитаны.
Можешь создать таблицу user_theme_view c полями user_id|themes_list|created_at|updated_at. В themes_list хранить ID тем через какой-нибудь разделитель (например: 1|2|3), в created_at дату cоздания записи, в updated_at последнего обновления. Список с темами из этой таблицы загружается в сессию при входе в систему. Created_at и updated_at нужны для того, чтобы выявлять и удалять устаревшие и мертвые записи из таблицы
Покинул форум
Сообщений всего: 32
Дата рег-ции: Июнь 2011
Помог: 0 раз(а)
вот в дле форум topic_id forum_id user_id time
такая таблица, но это же если большой форум, то сколько записей получается тогда минимум количество тем*на количество пользователей, поменьше никак?
в других более популярных форумах не знаю как так как там много таблиц и долго разбираться
нужно хранить все это в базе данных mysql (чтобы когда пользователь браузер переставил или еще что это было)
Все гости форума могут просматривать этот раздел. Только зарегистрированные пользователи могут создавать новые темы в этом разделе. Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.