Portál AbcLinuxu, 14. května 2025 05:43
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:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.