sql >> Database >  >> RDS >> PostgreSQL

Voortschrijdend gemiddelde in postgresql

SQL Fiddle

select
    "date",
    shop_id,
    amount,
    extract(dow from date),
    case when
        row_number() over (order by date) > 3
        then
            avg(amount) OVER (
                ORDER BY date DESC
                ROWS BETWEEN 1 following AND 3 FOLLOWING
            )
        else null end
from (
    select *
    from ro
    where extract(dow from date) = 4
) s

Wat er mis is met de vraag van de OP is de framespecificatie:

ROWS BETWEEN 0 PRECEDING AND 2 FOLLOWING

Afgezien daarvan vermijdt mijn vraag onnodig computergebruik door donderdag te filteren voordat de dure vensterfuncties worden toegepast.

Als het nodig is om te partitioneren op shop_id, voeg dan uiteraard de partition by shop_id naar beide functies, avg en row_number .



  1. Ondersteuning voor meerdere talen in 11i/R12

  2. Koppeling naar Salesforce-gegevens in Microsoft Access

  3. is er een PRODUCT-functie zoals er een SOM-functie is in Oracle SQL?

  4. match de datum van datepicker met de beschikbare databasedag en toon het resultaat