日付と金額の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;