За сегодня:

createdate>= CURDATE()";

 

За вчера:

createdate>= (INTERVAL -1 DAY + curdate()) AND createdate < CURDATE()

 

 

За неделю:

createdate > DATE_SUB(CURDATE(), INTERVAL (DAYOFWEEK(CURDATE()) -1) DAY) AND messagedate < DATE_ADD(CURDATE(), INTERVAL (9 - DAYOFWEEK(CURDATE())) DAY)

 

За месяц:

createdate > LAST_DAY(DATE_SUB(CURDATE(), INTERVAL 1 MONTH))AND messagedate< DATE_ADD(LAST_DAY(CURDATE()), INTERVAL 1 DAY)

 

Выборка MySQL за день, вчера, неделю, месяц
Метки:    

2 thoughts on “Выборка MySQL за день, вчера, неделю, месяц

  • 1 июля 2013 на 04:21
    Постоянная ссылка

    >>За вчера:
    не работает 1 числа каждого месяца

    mysql> select curdate();
    +————+
    | curdate() |
    +————+
    | 2013-07-01 |
    +————+
    1 row in set (0.00 sec)

    mysql> select curdate()-1;
    +————-+
    | curdate()-1 |
    +————-+
    | 20130700 |
    +————-+
    1 row in set (0.00 sec)

    Ответить

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *

Нажимая на кнопку "Отправить комментарий", я даю согласие на обработку персональных данных и соглашаюсь c политикой конфиденциальности *