Byly rozdány Ceny Velkého bratra (Big Brother Awards) za rok 2022 pro největší slídily pořádané nevládní organizací Iuridicum Remedium. Dlouhodobý slídil: Microsoft. Firemní slídil: Seznam. Úřední slídil: Nejvyšší správní soud. Výrok Velkého bratra: Marian Jurečka. Pozitivní cena: NoLog.
Byla představena online vzdělávací platforma Ada Computer Science pro učitele, studenty a kohokoli, kdo se zajímá o informatiku. Stojí za ní Raspberry Pi Foundation a Univerzita v Cambridgi.
GitHub má nový RSA SSH klíč. Předchozí soukromý klíč byl krátce vystaven na GitHubu.
Společnost Framework Computer představila (YouTube) nové modulární notebooky: Laptop 13 s Intel Core nebo AMD Ryzen a Laptop 16 (YouTube).
Bylo vydáno Ubuntu 20.04.6 LTS, tj. šesté opravné vydání Ubuntu 20.04 LTS s kódovým názvem Focal Fossa. Přehled novinek v poznámkách k vydání a v přehledu změn.
Připojit neznámý USB flash disk do počítače může být nebezpečné. Dokonce může jít i o život. Někdo rozeslal ekvádorským novinářům USB flash disky, které po připojení do počítače explodují [BBC, Twitter].
Byla vydána nová verze 7.4 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu.
Byla vydána verze 11.0 s kódovým jménem Aramo linuxové distribuce Trisquel GNU/Linux. Založena je na Ubuntu 22.04 LTS a podporována bude do roku 2027. Trisquel patří mezi svobodné distribuce doporučované Nadací pro svobodný software (FSF).
Mozilla založila startup Mozilla.ai a vložila do něj 30 milionů dolarů. Cílem je vývoj důvěryhodné, nezávislé a open source AI.
Po půl roce vývoje od vydání verze 43 bylo vydáno GNOME 44 s kódovým názvem Kuala Lumpur. Přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře. Krátké představení na YouTube.
To co by Vám pomohlo je funkce rank, která patří do kategorie OLAP funkcí. K Vaší smůle MySQL tuto kategorii funkcí neumí. Nicméně tento nedostatek lze v MySQL snad obejít pomocí uživatelsky definovaných proměných. Hledejte na google "MySQL rank". Řešení je asi hned první odkaz. Rankovací výraz budete muset asi vylepšit o reset čítače při změně místa. Tedy kromě čítače si budete potřebovat pamatovat ještě název skupiny (= misto). Výsledek by mohl vypadat nějak takto:
set @rownum=0, @place=null;
select
misto,datum,stav
from (
select
case when @place = misto then @rownum := @rownum + 1
else case when @place := misto
then @rownum:=0
else @rownum:=0
end
end as rank
,misto,datum,stav
from TABULKA
order by misto,datum
) t
where rank <= 2
Před naprogramováním by jste si měl rozebrat ještě jeden případ. A to kdy je pro jeden den a jedno místo více jak 2 měření. Kolik by se v tomto případě mělo vrátit záznamů? Všechny (tedy více něž dva za skupinu) a nebo 2 náhodné?
Napište zda to zafungovalo.
SELECT h.datum, h.prov, h.stav
FROM hladiny AS h
WHERE h.ID = (
SELECT t.ID
FROM hladiny AS t
WHERE t.prov = h.prov
ORDER BY datum DESC
LIMIT 0 , 1 )
ORDER BY stav
a toto pro n-posledních
SELECT h.datum, h.prov, h.stav
FROM hladiny AS h
WHERE h.ID IN (
SELECT t.ID
FROM hladiny AS t
WHERE t.prov = h.prov
ORDER BY datum DESC
LIMIT 0 , n )
ORDER BY stav
co mně na tomhle řešení štve, je (alespoň se domnívám) plýtvání výkonem. Při mnoha záznamech je to myslím nepoužitelné. Možná má MySQL nějaké optimalizace, ale brutalita tohoto způsobu dotazování mi nesedí.
jinak - co se týče více záznamů v jeden den, tak s tím nepočítám. Nebudou. Není potřeba.
Asi se podívám na filozofii toho vašeho kódu, musím to nejprve strávit, jak nechápu o čem kód je, tak není můj kamarád..
a děkuji za velmi dobré nasměrování.
Milan
select * from hladiny
where (misto,datum) in ( select misto,max(datum) from hladiny group by misto )
V kódu který jsem uvedl jsou dvě chyby:
order by misto,datum desc
@rownum:=1
a to v obou případech
Tiskni
Sdílej: