Как вывести значения полей таблицы за определенную дату

Бьюсь над задачей: как вывести все значения полей таблицы за определенную, указанную дату. Дата задается в виде 30.01.2013 - за месяц. Дата будет браться из переменной.

Нашел в гугле вариант за предыдущий месяц, но он не подходит:

/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }

select id from tab where date_format(real_time, '%Y%m') = date_format(date_add(now(), interval -1 month), '%Y%m');
 


Дата хранится в поле TIMESTAMP. Подскажите, куда копать?

1 ответов


Нашел в гугле вариант за предыдущий месяц, но он не подходит:

select id from tab where date_format(real_time, '%Y%m') = date_format(date_add(now(), interval -1 month), '%Y%m');


---
мда, гугле в наше время уже не тот.
Этот вариант довольно кривой, форматировать дату всех записей в таблице довольно накладно, особенно если в таблице будут миллионы записей, ко всем миллионам выполнится функция date_format(real_time, '%Y%m') и индексы использоваться не будут.
Выборка всех записей за предыдущий месяц должна быть примерно такой

SELECT id FROM tab WHERE real_time >= DATE_FORMAT(NOW() - INTERVAL 1 MONTH, '%Y-%m-01') AND real_time < DATE_FORMAT(NOW(), '%Y-%m-01')
 

Вместо NOW() - подставте свою дату в формате 'Y-m-d', например


SELECT id FROM tab WHERE real_time >= DATE_FORMAT('2013-01-30' - INTERVAL 1 MONTH, '%Y-%m-01') AND real_time < DATE_FORMAT('2013-01-30', '%Y-%m-01')