sql >> Databáze >  >> RDS >> PostgreSQL

Získejte poslední data z minulého týdne a sečtěte nějaký sloupec

Myslím, že to odpovídá vašemu očekávanému výsledku:

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

Výsledek:

+----+-------+----------------+---------+---------------------+-----+-----+-----+-----+
|    | 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 |
+----+-------+----------------+---------+---------------------+-----+-----+-----+-----+

Viz:http://rextester.com/ISHS42170

Pro podmínky, jako je „nejnovější“ zjišťuji, že použití ROW_NUMBER() OVER() je nejpohodlnější, protože umožňuje vrátit celý řádek každé „nejnovější“ události, což není tak jednoduché, pokud používáte MAX() a SKUPINA VYTVOŘENÁ. "Odlišné" výsledky jsou vráceny filtrováním řádků s hodnotou 1 vrácených funkcí.

+UPRAVIT

Místo použití where rn in (1,2) Věřím, že lepší způsob by byl lepší použít čárový kód v podmínkách OVER(PARTITION BY...), jako je tento:

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. Oracle SYS_GUID se nemění

  2. Jak vložit pole dat do mysql pomocí php

  3. Převod z ANSI na Oracle Join Syntax

  4. Chyba při použití připojení OLAP:Poskytovatel MSOLAP není registrován na místním počítači...