форум vBSupport.ru > vBulletin > Вопрос — Ответ
  • »
VBsupport перешел с домена .ORG на родной .RU Ура! Пожалуйста, обновите свои закладки - VBsupport.ru
 
 
 
 
Smalesh
В Черном списке
Default Считаем: придумать SQL запрос
0

Не силен в SQL, но для одной идеи надо решить две задачи:

Задача - подсчитать, сколько раз сказал %username% спасибо за промежуток времени.

Задача сложнее - подсчитать, сколько раз сказал %username% спасибо за промежуток времени в определенных разделах форума.

Если не трудно, набросайте идеи?
Bot
Yandex Bot Yandex Bot is online now
 
Join Date: 05.05.2005
Реклама на форуме А что у нас тут интересного? =)
 
 
Abraxas
Гость
Default

Quote:
Originally Posted by Smalesh View Post
подсчитать, сколько раз сказал %username% спасибо за промежуток времени
Кажется, это можно вывести в Просмотр комментариев к репутации, сделав выборку по нику и промежутку между датами.
 
 
mindframe
Специалист
 
mindframe's Avatar
Default
1

Smalesh, не знаю структуру таблиц этого хака, но дата там точно записывается, поэтому просто WHERE date < date.
Для формирования второго, уже надо будет покурить маны:
http://www.skillz.ru/dev/php/article...NER_OUTER.html
Первое что выбрал в гугле
 
 
Smalesh
В Черном списке
Default
0

Quote:
Originally Posted by Abraxas View Post
сделав выборку по нику и промежутку между датами.
Дык сама выборка и интересует.

Smalesh добавил 30.07.2013 в 18:01
Quote:
Originally Posted by mindframe View Post
Для формирования второго, уже надо будет покурить маны:
О. Респект, ткнули куда надо. Первое - там ерунда, там все в одной табличке
Code:
CREATE TABLE `vb3_post_thanks` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `userid` int(10) NOT NULL,
  `username` varchar(50) NOT NULL,
  `date` int(10) NOT NULL,
  `postid` int(10) NOT NULL,
  `__imported` tinyint(1) unsigned NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`),
  KEY `postid` (`postid`)
) ENGINE=MyISAM
А вот второе надо как-то крутить JOIN

Last edited by Smalesh : 07-30-2013 at 06:01 PM. Reason: Добавлено сообщение
 
 
Abraxas
Гость
Default

Smalesh, у тебя какой хак спасиб установлен?
 
 
Smalesh
В Черном списке
Default
0

Quote:
Originally Posted by Abraxas View Post
какой хак спасиб установлен
Классический 7.7 под 3.8. Но там есть и зеркальный Post Groan, потому и вынес отдельной темой.

Надо сесть и помозговать)
 
 
Abraxas
Гость
Default

Smalesh, у меня другой, наверное, и у меня есть вот такое



я и подумала...

Видимо, в твоем этого нет, или тебе надо не это. Сорри
 
 
Smalesh
В Черном списке
Default
0

Quote:
Originally Posted by Abraxas View Post
и у меня есть вот такое
И у меня такое есть. Но у меня интерес посчитать это в скрипте)
 
 
OldEr
Специалист
Master
 
OldEr's Avatar
Default
1

Quote:
Originally Posted by Smalesh View Post
сколько раз сказал %username% спасибо за промежуток времени.
PHP Code:
$result $vbulletin->db->query_first("SELECT count(*) AS count FROM " TABLE_PREFIX "post_thanks WHERE userid = $userid AND date >= UNIX_TIMESTAMP($from) AND date < UNIX_TIMESTAMP($to)"); 
Quote:
Originally Posted by Smalesh View Post
Задача сложнее - подсчитать, сколько раз сказал %username% спасибо за промежуток времени в определенных разделах форума.
PHP Code:
$result $vbulletin->db->query_first("SELECT count(*) AS count FROM " TABLE_PREFIX "post_thanks WHERE userid = $userid AND date >= UNIX_TIMESTAMP($from) AND date < UNIX_TIMESTAMP($to) AND postid IN (SELECT postid FROM " TABLE_PREFIX "post WHERE forumid IN ($forums)"); 
, где
$userid – ID-пользователя (лучше выбирать по ID, чем по нику)
$from – дата начала выборки, например,
Code:
2003-03-01 00:00:00
$to – дата окончания выборки, например,
Code:
2003-03-31 00:00:00
$forums – строка, содержащая ID-разделов, разделённых запятой, например,
Code:
1, 2, 3
$result['count'] – переменная с результатом.

P.S: Вместо использования UNIX_TIMESTAMP можно предварительно переводить даты в UNIX-формат непосредственно в скрипте по средствам PHP.

Last edited by OldEr : 07-30-2013 at 09:28 PM.
 
 
Smalesh
В Черном списке
Default
1

Во блин. А с этой стороны я что-то не подумал
Code:
AND postid IN (SELECT postid FROM " . TABLE_PREFIX . "post WHERE forumid IN ($forums)")
Респект.
 


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off




All times are GMT +4. The time now is 10:54 PM.


Powered by vBulletin® Version PreModed
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Loading...