Добро пожаловать в форум, Guest  >>   Войти | Регистрация | Поиск | Правила | В избранное | Подписаться
Все форумы / PostgreSQL Новый топик    Ответить
 Как вывести средние значения с помощью оконных функций.  [new]
Moneta13
Member

Откуда:
Сообщений: 57
Здравствуйте, столкнулся с такой проблемой, к каждой дате привязал знак зодиака, а теперь надо высчитать среднее значение в каждом году у каждого знака, обычный group by не помогает, так как знак козерога встречается 2 раза в год, а вот вытащить как-то через оцонную функцию среднее значение вот таких вот секий можно? Заранее спасибо

К сообщению приложен файл. Размер - 46Kb
21 апр 21, 16:59    [22312051]     Ответить | Цитировать Сообщить модератору
 Re: Как вывести средние значения с помощью оконных функций.  [new]
бабушкин зайчик
Member

Откуда: сетевой
Сообщений: 120
группировка по годам, группировка по знакам, sum(exchangeratebel_rate) / (SELECT count(*) FROM tbl WHERE zodiac_sign = 'Capricorn' AND extract(YEAR FROM years) = 2000)
если в таблице лишние данные, то исправляйте/фильтруйте

Сообщение было отредактировано: 21 апр 21, 20:05
21 апр 21, 20:12    [22312140]     Ответить | Цитировать Сообщить модератору
 Re: Как вывести средние значения с помощью оконных функций.  [new]
Moneta13
Member

Откуда:
Сообщений: 57
Я наверное не так выразился. в таблице имеются данные за 20 лет, каждой дате соостветсвует свой знак зодиака, мне нужно посчитать средний рейт именно по зодиакальному году, а не календарному. Поэтому из каждой из таких секций, когда меняется знак зоиака, нужно расчитать средний рейт
21 апр 21, 20:21    [22312141]     Ответить | Цитировать Сообщить модератору
 Re: Как вывести средние значения с помощью оконных функций.  [new]
бабушкин зайчик
Member

Откуда: сетевой
Сообщений: 120
знаки зодиака меняются ежемесячно, а не в год
22 апр 21, 12:19    [22312407]     Ответить | Цитировать Сообщить модератору
 Re: Как вывести средние значения с помощью оконных функций.  [new]
Guzya
Member

Откуда:
Сообщений: 720
Приведите пример данных и результата.

А до того, логичным кажется, то, что написали выше

select extract(YEAR FROM years) as "year", zodiac_sign, avg(exchangeratebel_rate) from tbl group by extract(YEAR FROM years), zodiac_sign


Сообщение было отредактировано: 22 апр 21, 17:45
22 апр 21, 17:49    [22312718]     Ответить | Цитировать Сообщить модератору
Все форумы / PostgreSQL Ответить