Мне нужно создать отчет, который содержит количество каждого рекламного кода, используемого в течение определенной недели. Пример структуры таблицы:Самый эффективный способ в MySQL для получения значений за определенную неделю?
CREATE TABLE `user_promo_codes` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`user_id` bigint(20) unsigned NOT NULL,
`promo_code` longtext NOT NULL,
`last_updated` datetime NOT NULL,
PRIMARY KEY (`id`),
)
Что я хочу - это количество каждого конкретного промо-кода, используемого в течение данной недели. Что у меня сейчас есть:
SELECT promo_code, count(*) AS count
FROM user_promo_codes
WHERE last_updated BETWEEN
FROM_UNIXTIME(# one week ago
UNIX_TIMESTAMP(DATE_SUB(NOW(), INTERVAL 7 DAY)) - TIME_TO_SEC(NOW())
)
AND
FROM_UNIXTIME(
UNIX_TIMESTAMP(NOW()) - TIME_TO_SEC(NOW())
)
GROUP BY value
Есть ли более эффективный способ сделать это?
Вы * действительно * хотите сделать последнее_определенное поле индексом. :-) – 2010-12-07 22:14:02