abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
dnes 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 0
včera 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 23
včera 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 26
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 781 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Spotřeba vody za období ze stavu vodoměru

7.10.2014 01:00 pedro
Spotřeba vody za období ze stavu vodoměru
Přečteno: 1346×
Zdravím,

asi nejsem dost zkušený, problém vypadá triviálně, ale lámu si hlavu s elegantním řešením.

Mějme tabulku datum date,stav integer. Například:
1.3.2014 1000
1.6.2014 1500
1.9.2014 2100
což je datum a stav vodoměru v daný den. Chci z toho dostat toto:
1.3.2014-1.6.2014 500
1.6.2014-1.9.2014 600
tedy kolik se spotřebovalo vody vždy mezi jednotlivými zápisy. Prosím o radu na elegantní řešení v PostgreSQL.

Díky.

Řešení dotazu:


Odpovědi

Tarmaq avatar 7.10.2014 09:17 Tarmaq | skóre: 39
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
SELECT s1.datum AS od, s2.datum AS do, s2.stav - s1.stav AS rozdil
FROM spotreba_vody s1
CROSS JOIN spotreba_vody s2
WHERE s1.datum < s2.datum
Na PostgreSQL netestovano, ale melo by to fungovat. Ma to jednu odlisnost, vraci to i rozdil mezi 1.3. a 1.9.
Don't panic!
Tarmaq avatar 7.10.2014 09:52 Tarmaq | skóre: 39
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
SELECT x.od, x.do, s2.stav - s1.stav AS rozdil
FROM
(
  SELECT 
    x1.datum AS od
  , (SELECT MIN(x2.datum) FROM spotreba_vody x2 WHERE x2.datum > x1.datum) AS do
  FROM spotreba_vody x1
) x
JOIN spotreba_vody s1 ON s1.datum = x.od
JOIN spotreba_vody s2 ON s2.datum = x.do
Tohle vrati jen ty dva zaznamy, ale opet nevim, jestli funguje i na postgresu..
Don't panic!
7.10.2014 09:36 Tomáš
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru

Máte dvě možnosti. První méně efektivní se self joinem a druhý lepší s window funkcemi.

  1. select 
      A.dt
      ,min(B.dt)
      ,min(B.val order by B.dt)-A.val 
    from T as A 
    join T as B on A.dt<B.dt 
    group by A.*
    
  2. select 
      A.dt
      ,max(A.dt) over( order by A.dt rows between current row and 1 following)
      ,max(A.val) over( order by A.dt rows between current row and 1 following)-A.val
    from A
    

Psáno bez jakékoliv kontroly, takže tam budou asi nějaké chybky. Ale jako nápověda je to dostatečné. BTW: Co když není datum unikátní?

rADOn avatar 7.10.2014 13:45 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
Ta druha varianta se mi libi… umi neco takovyho mysql?
"2^24 comments ought to be enough for anyone" -- CmdrTaco
7.10.2014 14:11 Tomáš
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
Pokud vím, tak ne. Musel by jste si pomoci cursorem.
7.10.2014 16:01 pedro
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
Z hlavy (skoro) perfektní, jen na konci zbude řádek, kde je stejné počáteční i koncové datum a nulová spotřeba. Výsledný select tedy vypadá takto:
select * from
(
select
  voda.datum as zacatek
  ,max(voda.datum) over( order by voda.datum rows between current row and 1 following) as konec
  ,max(voda.stav) over( order by voda.datum rows between current row and 1 following)-voda.stav as spotreba
from myschema.voda
) foo
where zacatek != konec;
Nejedinečné datum s různými stavy vodoměru je blbost, tak přidán constraint (ve skutečnosti je to timestamp, ne datum).

K dokonalosti ještě chybí ošetřit přetočení či výměnu vodoměru, ale to teď řešit nebudu.
Řešení 1× (Tarmaq)
okbob avatar 7.10.2014 11:46 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
Co např.:
postgres=> select * 
              from (select mereno, hodnota - lag(hodnota) over (order by mereno) as spotreba 
                       from odecet order by 1) s 
             where spotreba is not null;
   mereno   | spotreba 
------------+----------
 2014-01-06 |      500
 2014-01-09 |      600
(2 rows)
Kartézákům se pokud možno vyhýbejte - pro větší data to může být docela pomalé, a navíc zápis s window funckcemi je výrazně čitelnější.
7.10.2014 15:37 pedro
Rozbalit Rozbalit vše Re: Spotřeba vody za období ze stavu vodoměru
Moc všem děkuji. Ano, šlo mi hlavně o window funkce, které jsem pro sebe objevil teprve včera ;).

Kartézákům jsem se chtěl vyhnout, ačkoli v mém případě by to asi nevadilo, protože se jedná skutečně o vodoměr v bytovém domě a asi ho nebudu odečítat častěji než 1x týdně, takže i za léta řádově stovky řádků.

Tak teď ještě ty window funkce pochopit a naučit se je.

S vodou není legrace, jeden protékající záchod v domě dokáže udělat na faktuře za vodu opravdu pořádný vítr.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.