MySQL в тот же день в прошлом году - PullRequest
0 голосов
/ 10 февраля 2012

Аргументы в пользу начала / конца недели, как получить запрос, который выбирается из той же таблицы для сравнения числа на этой неделе с той же неделей прошлого года?

Каждый раз, когда я пытаюсь это сделать, число становится завышенным, потому что оно выполняет кросс-тип продукта.

Что-то вроде

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`)

Ответы [ 2 ]

2 голосов
/ 10 февраля 2012

Как насчет следующего?

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)
0 голосов
/ 10 февраля 2012

Я рекомендую ответ @ MartinJansen - MySQL работает намного лучше по строкам, чем по столбцам, особенно , когда вы хотите извлечь только определенную неделю.

Однако, если вы хотите, чтобы это было по столбцам или если вы хотели, чтобы это длилось более одной конкретной недели, вы можете попробовать:

mysql> SELECT * from sales;
+------------+------+
| date       | sold |
+------------+------+
| 2011-01-01 |    1 |
| 2011-01-02 |   10 |
| 2011-01-03 |    3 |
| 2012-01-01 |   10 |
| 2012-01-02 |   20 |
+------------+------+

SELECT CONCAT('week',WEEK(t.`date`)) as week, 
 SUM(IF(YEAR(t.`date`)=YEAR(DATE_ADD(NOW(), INTERVAL - 1 YEAR)),t.sold,0)) as `2011`, 
 SUM(IF(YEAR(t2.`date`)=YEAR(NOW()),t2.sold,0)) as `2012`
FROM sales t
LEFT JOIN sales t2
ON t.date = t2.date     --could add WHERE WEEK(t.date)=... to restrict week
GROUP BY WEEK(t.date)

+-------+------+------+
| week  | 2011 | 2012 |
+-------+------+------+
| week0 |    1 |    0 |
| week1 |   13 |   30 |
+-------+------+------+

(Вам нужно прочитать точное определение недель в MySQL).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...