PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Uzyskaj tylko najnowsze dane z ostatniego tygodnia i zsumuj jakąś kolumnę

Myślę, że to pasuje do oczekiwanego wyniku:

select "user", "contact", "barcode", "date", "in", "out","dif"
     , sum("in"-"out") over(partition by "user", "contact") as "sum"
from (
    select "user", "contact", "barcode", "date", "in", "out","dif"
    , lag(dif,1) over(partition by "user", "contact" order by "date" ASC) prevdif
    , row_number() over(partition by "user", "contact" order by "date" DESC) rn
    from "table1" 
    where date_trunc('day', "date") <= '2017-06-25' ::date - (  interval '1 week')::interval 
    and "date" >  '2017-06-25'::date - (  interval '2 weeks')::interval 
    ) d
where rn in (1,2) and prevdif is not null
order by 1,2,4 DESC

Wynik:

+----+-------+----------------+---------+---------------------+-----+-----+-----+-----+
|    | user  |    contact     | barcode |        date         | in  | out | dif | sum |
+----+-------+----------------+---------+---------------------+-----+-----+-----+-----+
|  1 | USER2 | Guillermo Tole |  987654 | 16.06.2017 05:27:00 | 500 | 420 |  80 | 170 |
|  2 | USER2 | Guillermo Tole |  281460 | 15.06.2017 05:36:00 | 310 | 220 |  90 | 170 |
|  3 | USER3 | Juan Rulfo     |  123456 | 15.06.2017 05:37:00 | 450 | 300 | 150 | 150 |
|  4 | USER3 | Pepito Marquez |  346234 | 15.06.2017 05:37:00 | 600 | 360 | 240 | 240 |
+----+-------+----------------+---------+---------------------+-----+-----+-----+-----+

Zobacz:http://rextester.com/ISHS42170

W przypadku warunków takich jak „najnowsze” uważam, że użycie ROW_NUMBER() OVER() jest najwygodniejsze, ponieważ pozwala na zwrócenie całego wiersza każdego „najnowszego” zdarzenia, co nie jest tak proste, jeśli używasz MAX() i GRUPUJ WEDŁUG. „Wyraźne” wyniki są zwracane przez filtrowanie wierszy o wartości 1 zwróconej przez funkcję.

+EDYTUJ

Zamiast używać where rn in (1,2) Uważam, że lepszym sposobem byłoby użycie kodu kreskowego w warunkach OVER(PARTITION BY...), takich jak:

select "user", "contact", "barcode", "date", "in", "out","dif"
     , sum("in"-"out") over(partition by "user", "contact") as "sum"
from (
    select "user", "contact", "barcode", "date", "in", "out","dif"
    , lag(dif,1) over(partition by "user", "contact", "barcode" order by "date" ASC) prevdif
    , row_number() over(partition by "user", "contact", "barcode" order by "date" DESC) rn
    from "table1" 
    where date_trunc('day', "date") <= '2017-06-25' ::date - (  interval '1 week')::interval 
    and "date" >  '2017-06-25'::date - (  interval '2 weeks')::interval 
    ) d
where rn = 1 and prevdif is not null
order by 1,2,4 DESC

http://rextester.com/SCV98254



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak połączyć się z bazą danych Postgres bez hasła za pomocą pg-promise?

  2. Wybierz liczbę odpowiedzi MCQ na podstawie odpowiedzi na poprzednie pytanie

  3. Który typ kolumny PostgreSQL powinien być używany do przechowywania Java BigDecimal?

  4. Wyszukiwanie tablicy jsonb w PostgreSQL

  5. Niejednoznaczne odniesienie do kolumny w INSERT ... ON CONFLICT DO UPDATE