2010-12-07 63 views
1

我需要提供一份报告,提供特定周内使用的每种特定促销代码的计数。示例表结构: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 

有没有更高效的方法来做到这一点?

+0

您*真的*想让last_updated字段成为索引。 :-) – 2010-12-07 22:14:02

回答

1

对于您所显示的数据类型,这应该在现在的之前一周正常工作。

SELECT promo_code, COUNT(*) AS count 
FROM user_promo_codes 
WHERE last_updated BETWEEN DATE_SUB(NOW(), INTERVAL 7 DAY) AND NOW() 
GROUP BY promo_code 

旁白:

  • 使用的promo_code一个LONGTEXT将确保在磁盘上的一个临时表。可能最好做一个VARCHAR(N)
  • 正如middaparka指出的那样,当表格增长时,last_updated上的索引将变得无价。

更新

随着NOW() - >最近Wedneday @00:00:00

SELECT promo_code, COUNT(*) AS count 
FROM user_promo_codes 
WHERE last_updated BETWEEN 
DATE_SUB(CONCAT(DATE_SUB(CURDATE(), INTERVAL WEEKDAY(CURDATE())+5 DAY) ,' 00:00:00'), INTERVAL 7 DAY) 
AND 
CONCAT(DATE_SUB(CURDATE(), INTERVAL WEEKDAY(CURDATE())+5 DAY) ,' 00:00:00') 
GROUP BY promo_code 

这仅仅是上述与

CONCAT(DATE_SUB(CURDATE(), INTERVAL WEEKDAY(CURDATE())+5 DAY) ,' 00:00:00') 

NOW()小号换英寸

+0

这就是我所需要的大部分方法,但重要的是该BETWEEN子句的端点应如上所述。我不能保证脚本将以NOW()将始终是周三早上午夜的方式运行。 – 2010-12-07 22:39:49