Je dois produire un rapport indiquant le nombre de codes promotionnels particuliers utilisés au cours d'une semaine donnée. Exemple de structure de tableau:Le moyen le plus efficace dans MySQL pour récupérer des valeurs dans une semaine donnée?
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`),
)
Ce que je veux, c'est un décompte de chaque code promo particulier utilisé dans une semaine donnée. Ce que j'ai en ce moment:
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
Existe-t-il un moyen plus efficace de le faire?
Vous voulez * vraiment * faire du champ last_updated un index. :-) –