Meowth[OGD] Опубликовано 15 Июля 2003 Жалоба Поделиться Опубликовано 15 Июля 2003 Вообщем тема такая. На борде есть спам-форум. Мне нужно выявить самого спамящего именно в нем за последний месяц... Вот сижу никак запрос не организую, может кто даст какой совет? Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Meowth[OGD] Опубликовано 15 Июля 2003 Автор Жалоба Поделиться Опубликовано 15 Июля 2003 $DB->query( "SELECT COUNT(p.pid) as tot_posts, p.topic_id, p.author_name, p.author_id FROM ibf_topics t, ibf_posts p WHERE p.topic_id=t.tid AND t.forum_id='1' AND t.pinned='0' GROUP BY p.author_name ORDER BY tot_posts DESC"); Вот вроде такого я сваял правильно ли? Добавлено: Поясню t.forum_id='1' - ид спам форума t.pinned='0' - чтобы считались только незакрепленные темы Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Meowth[OGD] Опубликовано 15 Июля 2003 Автор Жалоба Поделиться Опубликовано 15 Июля 2003 Вообщем если кому интересно могу выложить хак Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
theIggs Опубликовано 15 Июля 2003 Жалоба Поделиться Опубликовано 15 Июля 2003 Хм... Ну, в принципе, правильно... Так если, по мелочи какие ошибки... Например, надо по идее проверять p.queued=0 и t.approved=1 (это значит, что пост прошёл премодерирование), потом - ты же хочешь за месяц? Тогда нужно ещё в раздел WHERE добавлять post_date > 30*24*3600 или что-то в этом роде... или же использовать в скрипте microtime, чтоб получить именно от начала текущего месяца... Ну и ещё группировать нужно всё же по p.author_id, так надёжней... Добавлено: В общем, запустил твой запрос у себя - всё сработало. ЗЫpost_date > 30*24*3600Енто надо будет в скрипте рассчитывать, а в запрос подставлять уже post_date > $date... Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Meowth[OGD] Опубликовано 15 Июля 2003 Автор Жалоба Поделиться Опубликовано 15 Июля 2003 Я так и сделал =)) $time = time() - 2592000; $DB->query( "SELECT COUNT(p.pid) as tot_posts, p.topic_id, p.author_name, p.author_id, p.post_date FROM ibforumstopics t, ibforumsposts p WHERE p.topic_id=t.tid AND p.post_date > '".$time."' AND t.forum_id='1' AND t.pinned='0' GROUP BY p.author_name ORDER BY tot_posts DESC"); Я может и натупил тут, но для первого опыта в SQL наверное сойдет? Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
theIggs Опубликовано 16 Июля 2003 Жалоба Поделиться Опубликовано 16 Июля 2003 Советы начинающему скриптописцу: Когда считаешь время, лучше не выпендриваться с рассчётами, а писать просто time - 31*24*3600 (31 день по 24 часа по 3600 секунд в часе). Так меньше вероятность ошибки. Разрывать запрос mySQL в случае '".$time."' не обязательно - можно писать прямо внутри кавычек p.post_date > $time. PHP без проблем рендерит переменные прямо в запросах, если они не включают сложных частей типа [] () Если скрипт работает с базой через стандартный драйвер mySQL (sources/Drivers/mySQL.php), то подставлять свои префиксы таблиц необязательно. Можно писать стандартно ibf_topics, ibf_posts - драйвер сам подставит нужные префиксы:$the_query = preg_replace("/ibf_(\S+?)([\s\.,]|$)/", $this->obj['sql_tbl_prefix']."\\1\\2", $the_query); Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Meowth[OGD] Опубликовано 16 Июля 2003 Автор Жалоба Поделиться Опубликовано 16 Июля 2003 1. Понял учту2. Я знаю это просто осталось наследие от моих попыток 3. И это знаю, просто у меня форум сам это заменил почему то Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Рекомендуемые сообщения
Присоединиться к обсуждению
Вы можете ответить сейчас, а зарегистрироваться позже. Если у вас уже есть аккаунт, войдите, чтобы ответить от своего имени.