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í
×

dnes 13:11 | Nová verze

Po téměř dvou letech byla vydána nová verze 4.0 linuxové distribuce Audiophile Linux (též AP-Linux-V4). Tato distribuce vychází z Arch Linuxu, používá systemd, správce oken Fluxbox a vlastní real-time jádro pro nižší latence. Z novinek můžeme jmenovat podporu nových procesorů Intel Skylake a Kaby Lake nebo možnost instalace vedle jiných OS na stejný disk. Pokud se zajímáte o přehrávání hudby v Linuxu, doporučuji návštěvu webu této

… více »
Blaazen | Komentářů: 0
včera 18:55 | Nová verze

Byla vydána nová stabilní verze 1.9 (1.9.818.44) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují podporu nového vyhledávače Ecosia. Ten z příjmů z reklam podporuje výsadbu stromů po celém světě (YouTube). Nově lze přeskupovat ikonky rozšíření nebo řadit poznámky. Nejnovější Vivaldi je postaveno na Chromiu 58.0.3029.82.

Ladislav Hagara | Komentářů: 17
včera 17:00 | Nová verze

Byla vydána verze 3.7.0 svobodného systému pro správu obsahu (CMS) Joomla!. V oznámení o vydání (YouTube) se píše o 700 vylepšeních. Opraveno bylo také 8 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
včera 08:22 | Komunita

Grsecurity (Wikipedie) je sada bezpečnostních patchů pro linuxové jádro (porovnání se SELinuxem, AppArmorem a KSPP). Od září 2015 nejsou stabilní verze těchto patchů volně k dispozici. Dle včerejšího oznámení (FAQ) nejsou s okamžitou platností volně k dispozici už ani jejich testovací verze.

Ladislav Hagara | Komentářů: 54
26.4. 23:33 | Komunita

OpenBSD 6.1 vyšlo již 11. dubna. Po dvou týdnech byla vydána i oficiální píseň. Její název je Winter of 95 a k dispozici je ve formátech MP3 a OGG.

Ladislav Hagara | Komentářů: 0
26.4. 18:55 | Nová verze

Byla vydána verze 2017.1 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux. S vydáním verze 2016.1 se Kali Linux stal průběžně aktualizovanou distribucí. Aktualizovat jej lze pomocí příkazů "apt update; apt dist-upgrade; reboot".

Ladislav Hagara | Komentářů: 0
26.4. 18:22 | Nová verze

Po téměř pěti letech od vydání verze 2.00 byla vydána nová stabilní verze 2.02 systémového zavaděče GNU GRUB (GRand Unified Bootloader). Přehled novinek v souboru NEWS.

Ladislav Hagara | Komentářů: 24
26.4. 17:55 | Komunita

Vývojáři Debianu oznámili, že od 1. listopadu letošního roku nebudou jejich archivy dostupné pomocí protokolu FTP. Již v lednu oznámil ukončení podpory FTP kernel.org (The Linux Kernel Archives).

Ladislav Hagara | Komentářů: 28
26.4. 17:00 | Bezpečnostní upozornění

V oblíbeném webmailu postaveném na PHP SquirrelMail (Wikipedie) byla nalezena bezpečnostní chyba CVE-2017-7692, jež může být útočníkem zneužita ke spuštění libovolných příkazů a kompletnímu ovládnutí dotčeného serveru. Zranitelnost se týká pouze instancí, kde je pro transport používán Sendmail.

Ladislav Hagara | Komentářů: 3
26.4. 13:11 | Zajímavý článek

Soudní dvůr Evropské unie rozhodl (tisková zpráva) ve věci C-527/15: Prodej multimediálního přehrávače, který umožňuje zdarma a jednoduše zhlédnout na televizní obrazovce filmy protiprávně zpřístupněné na internetu, může představovat porušení autorského práva.

Ladislav Hagara | Komentářů: 32
Chystáte se pořídit CPU AMD Ryzen?
 (4%)
 (34%)
 (1%)
 (6%)
 (45%)
 (9%)
Celkem 339 hlasů
 Komentářů: 50, poslední včera 04:06
    Rozcestník

    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: 1357×
    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.