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 :: количество записей за последние 24 часа?

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
DelphinPRO
Отправлено: 02 Декабря, 2013 - 14:01:24
Post Id



Активный участник


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


Помог: 353 раз(а)




Извиняюсь за примитивный вопрос.

Есть поле типа DATETIME
как выбрать количество записей за последние 24 часа?

Как сделать то же самое с полем типа TIMESTAMP?


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
armancho7777777 Супермодератор
Отправлено: 02 Декабря, 2013 - 14:09:15
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




DelphinPRO пишет:
TIMESTAMP

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM table_name WHERE UNIX_TIMESTAMP(date_col) > UNIX_TIMESTAMP() - 24*60*60


DelphinPRO пишет:
DATETIME

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM table_name WHERE MICROSECOND(date_col) > MICROSECOND(NOW()) - 24*60*60*1000


CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM table_name WHERE TIMESTAMPDIFF(SECOND, date_col, now()) < 24*60*60

?

(Отредактировано автором: 02 Декабря, 2013 - 14:42:06)

 
 Top
Мелкий Супермодератор
Отправлено: 02 Декабря, 2013 - 14:32:04
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `table` WHERE date_col >= now() - interval 1 day

datetime или timestamp - поведут себя идентично.
Если вычисление now перекинуть на приложение, то в довесок будет работать кэш запросов.

armancho7777777, не стоит отказываться от индексов там, где они уместны. Если только тупой планировщик не догадается, что от него хотят на самом деле - ваши запросы не смогут использовать индексы.
функция(поле) не может использовать индекс по этому полю, для этого нужен функциональный индекс по результату выполнения этой функции. Но mysql такое не умеет.


-----
PostgreSQL DBA
 
 Top
armancho7777777 Супермодератор
Отправлено: 02 Декабря, 2013 - 14:43:38
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Мелкий пишет:
Если вычисление now перекинуть на приложение, то в довесок будет работать кэш запросов.

Не знал этих тонкостей )
 
 Top
DelphinPRO
Отправлено: 02 Декабря, 2013 - 14:47:31
Post Id



Активный участник


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


Помог: 353 раз(а)




Мелкий, благодарю. Вечером буду пробовать Улыбка
(Добавление)
А если now вычислять в php? то в каком формате поставлять в запрос?

так сработает?
PHP:
скопировать код в буфер обмена
  1. 'WHERE date_col >= '. time() .'  - interval 1 day'


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
Мелкий Супермодератор
Отправлено: 02 Декабря, 2013 - 15:31:24
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




DelphinPRO, подставлять обычный Y-m-d H:i:s

armancho7777777 пишет:
Не знал этих тонкостей )

В конце страницы есть перечисление ситуаций, когда запрос становится некешируемым: http://dev[dot]mysql[dot]com/doc/refman/[dot][dot][dot]e-operation[dot]html


-----
PostgreSQL DBA
 
 Top
armancho7777777 Супермодератор
Отправлено: 02 Декабря, 2013 - 15:45:49
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Ага, спасибо Мелкий!
 
 Top
DelphinPRO
Отправлено: 02 Декабря, 2013 - 19:08:17
Post Id



Активный участник


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


Помог: 353 раз(а)




Благодарю, все работает Улыбка


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB