У меня есть таблица с 2 столбцами, датой и суммой. Я хочу иметь возможность находить пики x дней в количестве. Итак, если у меня есть следующая таблица и я ищу, скажем, 3-дневные пики, то есть сумма в этот день выше, чем в любой другой день за 3 дня до или после, тогда эта дата будет выбрана.
date amount
2012-09-04 | 53137.47
2012-09-05 | 53137.2
2012-09-06 | 53137.54
2012-09-07 | 53138.58
2012-09-10 | 53138.73
2012-09-11 | 53138.28
2012-09-12 | 53138.22
2012-09-13 | 53138.48
2012-09-14 | 53140.14
2012-09-17 | 53139.82
2012-09-18 | 53139.86
2012-09-19 | 53140.01
2012-09-20 | 53139.75
2012-09-21 | 53139.82
2012-09-24 | 53139.01
2012-09-25 | 53138.93
2012-09-26 | 53138.48
2012-09-27 | 53138.83
2012-09-28 | 53138.62
Следует выбрать 2012-09-10, 2012-09-14
Я пытался использовать соединения и производные таблицы, но не могу заставить их работать.
попробовал следующее:
select * from a WHERE
amount=(select MAX(amount) from a where
date<date_add(date,interval 3 day) and
date>date_sub(date,interval 3 day));
а также
SELECT a1.*
FROM a AS a1
JOIN a AS a2 ON
(select * from a1 where
a2.DATE < a1.DATE + 3 and
a2.DATE > a1.DATE - 3) myalias
WHERE a1.amount > a2.amount;