sql >> Database teknologi >  >> RDS >> PostgreSQL

Glidende gennemsnit i 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

Det, der er galt med OP'ens forespørgsel, er rammespecifikationen:

ROWS BETWEEN 0 PRECEDING AND 2 FOLLOWING

Bortset fra det undgår min forespørgsel unødvendig databehandling ved at filtrere torsdage, før de dyre vinduesfunktioner anvendes.

Hvis det er nødvendigt at partitionere efter shop_id, skal du naturligvis tilføje partition by shop_id til begge funktioner, avg og row_number .



  1. Hvordan får man alle triggernavne fra en database ved hjælp af Java JDBC?

  2. Alle værdier ='s' i tabellen i PHP-fejl

  3. CONCAT søjler med Laravel 5 veltalende

  4. Integrering af søgning på en hjemmeside, hvor backend er MYSQL