Just 3 points ...
1) don't use "date" as a column name because it's a data type.
2) to_char(current_date, 'MM')||to_char(current_date, 'DD')
is equivalent to
to_char(current_date, 'MMDD')
3) you should get the same result with
...
where icao='KSFO'
and (EXTRACT (MONTH from date) = 9)
and (EXTRACT (DAY from date) BETWEEN 23 AND 29))
group by
...
Then you lost me with your 3 day idea =8-}
It might be depressingly slow but depending how time critical the report
is, you could do something like
select distinct (date)
date,
(select max(dc1.tmax) from daily_climate as dc1 where dc1.date
between (dc0.date - interval '1 day') and (dc0.date + interval '1 day'))
as max_tmax,
(select min(dc1.tmax) from daily_climate as dc1 where dc1.date
between (dc0.date - interval '1 day') and (dc0.date + interval '1 day'))
as min_tmax,
.................
from daily_climate as dc0
............
That's just something that might get you a result.
I didn't try it out.
Kai Carter schrieb:
I'm currently have an sql statement that selects a week of descriptive
statistics for various historical weather variables, sorted by date.
SELECT to_char(date, 'MM')||to_char(date, 'DD') as date, max(tmax) as
max_tmax, min(tmax) as min_tmax, avg(tmax) as mean_tmax, stddev(tmax)
as std_tmax, count(tmax) as count_tmax, sum(tmax) as sum_tmax,
variance(tmax) as var_tmax FROM daily_climate where icao='KSFO' and
(EXTRACT(MONTH from date) =9 and EXTRACT(DAY from date) = 23) or
(EXTRACT(MONTH from date) = 9 and EXTRACT(DAY from date) = 24) or
(EXTRACT(MONTH from date) = 9 and EXTRACT(DAY from date) = 25) or
(EXTRACT(MONTH from date) = 9 and EXTRACT(DAY from date) = 26) or
(EXTRACT(MONTH from date) =9 and EXTRACT(DAY from date) = 27) or
(EXTRACT(MONTH from date) = 9 and EXTRACT(DAY from date) = 28) or
(EXTRACT(MONTH from date) = and EXTRACT(DAY from date) = 29) group by
date order by date;
The problem is that I only have 36 years of data to work with, and I
would prefer to have a sample of ~100 rather than 30. So the idea
would be to have a sample statistics for each day made up of 3 days:
the current day, the day previous and the day after.
Is it possible to get this sort of a result with one select statement?
Thanks in advance for your responses,
Kai Carter
--
Sent via pgsql-sql mailing list (pgsql-sql@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-sql