MySQL 去年同一天

标签 mysql sql

除了关于周开始/结束的争论之外,如何获得从同一个表中选择的查询来比较本周与去年同一周的数字?

每次我尝试时,数字都会被夸大,因为它正在执行跨产品类型的操作。

类似

SELECT 
DATE(t1.`date`) AS 'Date', SUM(t1.`sold`), SUM(t2.`sold`)
FROM `table` AS t1
JOIN `table` AS t2 ON WEEK(t1.`date`) = WEEK(t2.`date`)
WHERE WEEK(t1.`date`) = WEEK(CURDATE()) AND YEAR(t1.`date`) = YEAR(CURDATE()) AND YEAR(t2.`date`) = YEAR(DATE_ADD(NOW(), INTERVAL - 1 YEAR))
GROUP BY DATE(t1.`date`)

最佳答案

下面这个怎么样?

mysql> SELECT * FROM test;
+------------+------+
| date       | sold |
+------------+------+
| 2012-02-10 |  100 |
| 2012-02-10 |  200 |
| 2011-02-10 |   50 |
| 2011-02-10 |   25 |
+------------+------+
4 rows in set (0.00 sec)

mysql> SELECT
    ->     CONCAT(WEEK(date), "-", YEAR(date)), SUM(sold)
    -> FROM
    ->     test
    -> WHERE
    ->     WEEK(`date`) = WEEK(NOW()) 
    ->     AND (YEAR(`date`) = YEAR(NOW()) OR YEAR(`date`) = YEAR(DATE_ADD(NOW(), INTERVAL - 1 YEAR))) 
    -> GROUP BY 
    ->     YEAR(date), WEEK(date);
+-------------------------------------+-----------+
| CONCAT(WEEK(date), "-", YEAR(date)) | SUM(sold) |
+-------------------------------------+-----------+
| 6-2011                              |        75 |
| 6-2012                              |       300 |
+-------------------------------------+-----------+
2 rows in set (0.00 sec)

关于MySQL 去年同一天,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9223335/

相关文章:

mysql - sql string cat 作为聚合函数 : cat multiple records together

MySQL左连接显示重复行

mysql OR/AND - 操作顺序如何工作

java - 将主键分配给 SQL 中的日期类型列

MySQL 触发器组合两个事件

php - 将一个复杂的查询变成 cakephp 的分页条件

mysql - SQL - 更新多个表,其中内部联接值来自第三个表

sql - 两列上的复合非空约束

mysql - sql 查询需要建议。需要统计某首歌在音乐节中播放的时间以及在决赛中获胜的次数

mysql - InnoDB 初始化警告