Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: Программирование на PHP

  Все выпуски  

RusFAQ.ru: Программирование на PHP


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Товарищ Бородин
Статус: Профессор
Рейтинг: 160
∙ повысить рейтинг >>
Hubbitus
Статус: 8-й класс
Рейтинг: 93
∙ повысить рейтинг >>
Волков Алексей
Статус: 3-й класс
Рейтинг: 36
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / PHP

Выпуск № 1109
от 09.04.2009, 02:05

Администратор:Калашников О.А.
В рассылке:Подписчиков: 464, Экспертов: 35
В номере:Вопросов: 1, Ответов: 3

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 164077: Здравствуйте. Я начинающий программист на PHP. Проблема у меня такая: я написал простенький форум, но не знаю как сделать индикацию того, что в теме есть новые сообщения. Поясню: один пользователь написал сообщение, а второй, не заходя в тему, мог ср...


Вопрос № 164.077
Здравствуйте. Я начинающий программист на PHP. Проблема у меня такая: я написал простенький форум, но не знаю как сделать индикацию того, что в теме есть новые сообщения. Поясню: один пользователь написал сообщение, а второй, не заходя в тему, мог сразу определить, что там есть сообщения, которых он еще не читал. И желательна индикация числа непрочитанных сообщений и последнего человека, написавшего сообщение. Спасибо.
Отправлен: 04.04.2009, 00:59
Вопрос задал: Krutozavrasky (статус: Посетитель)
Всего ответов: 3
Мини-форум вопроса >>> (сообщений: 5)

Отвечает: Товарищ Бородин
Здравствуйте, Krutozavrasky!
Ваши сообщения, очевидно, хранятся в БД - если так, то не лишним будет добавить в таблицу поле типа DATETIME или TIMESTAMP, в котором хранится дата и время чтения письма пользователем. До прочтения письма в поле лучше всего выставить нулевое значение. Определять становится очень легко - достаточно проверить таблицу на предмет наличия строк с полем(не знаю, как Вы его назовете, а я бы его назвал как-нибудь "reading_date") reading_date = 0. Сколько таких строк находится в таблице для соответствующего пользователя - столько сообщений у него и непрочитано.
Надеюсь, объяснил понятно.

С уважением, Товарищ Бородин
Ответ отправил: Товарищ Бородин (статус: Профессор)
Россия, Новосибирск
Тел.: +7-923-245-3366
----
Ответ отправлен: 04.04.2009, 08:27

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 246770 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5
    Комментарий оценки:
    Попробую сделать со сравнением дат.


    Отвечает: Волков Алексей
    Здравствуйте, Krutozavrasky!
    поправочка к ответу ув. тов. Бородина:
    его метод годится только для личных сообщений. Для вашей цели я бы создал отдельную таблицу: message_id | user_id | read_time и для каждого юзер_ид определял бы число непрочитанных разницей между общим числом сообщений и числом прочитанных данным юзером из этой таблицы. Кстати, эту разницу можно получить одним запросом к базе типа SELECT * FROM messages WHERE message_id NOT IN (SELECT message_id FROM read_messages WHERE user_id='$user_id') - этим запросом Вы получите не только число, но и список непрочитанных сообщений.
    Удачи!
    ---------
    Всё, что есть хорошего в жизни - либо незаконно, либо аморально, либо ведёт к ожирению...
    Ответ отправил: Волков Алексей (статус: 3-й класс)
    Ответ отправлен: 04.04.2009, 15:49

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 246790 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 4


    Отвечает: Rok-set
    Здравствуйте, Krutozavrasky!
    лично для меня как вариант лучшего соотношения загруженности БД к качеству сервиса - это таблица вида userID/sectionID/timestamp При заходе пользователем впервые в тему в этой таблице появляется строчка с временем. При повторном заходе на форум происходит запрос вида (найти строку в таблице с ID темы и ID пользователя), если строка не найдена значит тема создана после последнего посещения пользователем форума. если найдена - сверяем дату последнего сообщения в теме с датой в таблице и обновляем время. Таблица получается размером менее чем user_id*section_id потому что неактивные пользователи не делают в ней записей
    Ответ отправил: Rok-set (статус: Студент)
    Ответ отправлен: 06.04.2009, 09:17

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 246898 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное