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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [mysql] Помогите найти ошибку взапросе, mysql, выборка по дате unixtime 
V
    Опции темы
gers
Дата 6.9.2009, 14:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Здравствуйте,уважаемые!
Столкнулся с проблемой составления запроса, надо выбрать данные за последние 5 минут из определенных групп, получается выборка идет по полю log_time (формат unixtime), подскажите  где ошибка в запросе?

вот это место не работает, немогу понять почему:
Код

(log_time between '". time() ."-300' and  '". time() ."')


вот полный запрос, до log_time он правильный и рабочий.
Код

SELECT sum(incoming), sum(outgoing) from data WHERE id_group IN (2,4,6,8) AND (log_time between '". time() ."-300' and  '". time() ."');


Может быть есть проще способ выборки за последние 5 минут?
PM MAIL   Вверх
Ипатьев
Дата 6.9.2009, 14:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2232
Регистрация: 5.7.2009

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



ну, поскольку мы в разделе " Составление SQL-запросов", то, может быть, начать с того, что писать именно SQL запрос, а не кусок программы на каком-то языке, составляющей этот запрос?
PM MAIL   Вверх
gers
Дата 6.9.2009, 14:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Верно, это чтото я в php полез,

Вот подправил, но как от текущей даты в unixtime отнять пять минут?
Код

SELECT sum(incoming), sum(outgoing) from data WHERE id_group IN (2,4,6,8) AND (log_time between now()-'300' AND now())

PM MAIL   Вверх
gers
Дата 6.9.2009, 14:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



вобщем допер сам, немного погуглив, получается еще проще:

Код

SELECT sum(incoming), sum(outgoing) from data WHERE id_group IN (2,4,6,8) AND log_time >= UNIX_TIMESTAMP()-300

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




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


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

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