V stredu 11. 12. 2024 o 10:00 bude spustený zimný webinár zdarma. Na tomto webinári si ukážeme, ako nasadiť Zabbix v prostredí Kubernetes. Prevedieme vás procesom od inštalácie až po základné nastavenia Zabbix komponentov, zároveň si ukážeme nasadenie rôznych verzií Zabbixu.
… více »Chcete udržet krok s módou? Tak od ledna terminály, výchozí pozadí i celé desktopy v barvě hnědé jako čokoládová nebo kávová pěna. Barvou roku 2025 je PANTONE 17-1230 Mocha Mousse aneb #A47864.
Byla vydána nová verze 24.2 linuxové distribuce Manjaro (Wikipedie). Její kódové jméno je Yonada. Ke stažení je v edicích GNOME, KDE PLASMA a XFCE.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.12.
Byla vydána verze 31.0 svobodného softwaru OBS Studio (Open Broadcaster Software, Wikipedie) určeného pro streamování a nahrávání obrazovky počítače. Přehled novinek na GitHubu. Instalovat lze také z Flathubu.
Emulátory Box86 a Box64 umožňující spouštět linuxové aplikace pro x86 a x86_64 na jiných než x86 a x86_64 architekturách, například ARM a ARM64, byly vydány v nových verzích: Box86 0.3.8 a Box64 0.3.2. Ukázka možností na YouTube.
Byla vydána nová verze 6.1 neměnné (immutable) distribuce openSUSE Leap Micro určené pro běh kontejneru a virtuálních strojů. S vydáním verze 6.1 byla ukončena podpora verze 5.5.
Poslanci dnes ve třetím čtení schválili návrh zákona o digitálních financích. Cílem zákona je implementace předpisů Evropské unie v oblasti digitálních financí, konkrétně nařízení DORA (Digital Operational Resilience Act) o digitální provozní odolnosti finančního sektoru a nařízení MiCA (Markets in Crypto Assets) o trzích kryptoaktiv. Zákon nyní míří k projednání do Senátu ČR. U kryptoměn bude příjem do 100 tisíc Kč za zdaňovací období osvobozen od daně, podobně jako u cenných papírů, a to za podmínky jejich držení po dobu alespoň 3 let.
O víkendu (15:00 až 23:00) proběhne EmacsConf 2024, tj. online konference vývojářů a uživatelů editoru GNU Emacs. Sledovat ji bude možné na stránkách konference. Záznamy budou k dispozici přímo z programu.
Mozilla má nové logo a vizuální identitu. Profesionální. Vytvořeno u Jones Knowles Ritchie (JKR). Na dalších 25 let.
1.3.2014 1000 1.6.2014 1500 1.9.2014 2100což 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 600tedy 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:
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.datumNa PostgreSQL netestovano, ale melo by to fungovat. Ma to jednu odlisnost, vraci to i rozdil mezi 1.3. a 1.9.
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.doTohle vrati jen ty dva zaznamy, ale opet nevim, jestli funguje i na postgresu..
Máte dvě možnosti. První méně efektivní se self joinem a druhý lepší s window funkcemi.
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.*
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í?
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.
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ší.
Tiskni Sdílej: