Portál AbcLinuxu, 12. května 2025 19:28
Řešení dotazu:
SELECT * FROM Knihovna WHERE DatumVypujcky IN(SELECT MAX(DatumVypujcky) FROM Knihovna GROUP BY Uzivatel)
(Uzivatel, DatumVypujcky) IN (SELECT …)
– pokud ne, musíte to přepsat na JOIN:
SELECT Knihovna.* FROM Knihovna JOIN (SELECT Uzivatel, MAX(DatumVypujcky) AS DatumVypujcky FROM Knihovna GROUP BY Uzivatel) t USING (Uzivatel, DatumVypujcky)Pořád ale ten SELECT vrátí všechny výpůjčky uživatele v daný den. Pokud chcete jenom jednu výpůjčku, potřebujete mít nějakou sadu údajů Uzivatel+něco, která bude v rámci databáze unikátní, a podle které dokážete určit tu nejnovější výpůjčku – např. ta generovaná ID, jak píše EtDirloth. Pokud ta ID budou unikátní sama o sobě (tj. unikátní bude nejen dvojice Uzivatel,ID, ale i samotné ID), nepotřebujete do toho JOINu přidávat uživatele, protože ten už bude identifikován tím ID.
DatumVypujcky
klucom, tak nebude splnena podmienka "pouze posledni zaznam":
INSERT INTO Knihovna VALUES ('2016-03-31', 'Dracula', 'RadekXxX');
INSERT INTO Knihovna VALUES ('2016-03-31', 'Miss Betty', 'RadekXxX');
INSERT INTO Knihovna VALUES ('2016-03-31', 'The Mystery of the Sea', 'Filip Jirsák');
INSERT INTO Knihovna VALUES ('2016-04-01', 'The Jewel of Seven Stars', 'Filip Jirsák');
V MySQL by som skusil nejaku agregacnu funkciu - bud min, max, alebo group_concat:
SELECT k.DatumVypujcky, MIN(k.NazevKnihy) AS NazevKnihy, k.Uzivatel
FROM Knihovna AS k
JOIN (SELECT Uzivatel, MAX(DatumVypujcky) AS max_DatumVypujcky
FROM Knihovna
GROUP BY Uzivatel
) AS g ON (k.Uzivatel = g.Uzivatel AND k.DatumVypujcky = g.max_DatumVypujcky)
GROUP BY k.Uzivatel, k.DatumVypujcky;
To vsak bude asi pomale pri vacsich Knihovna
ch.MAX(DatumVypujcky)
nejaky autoinkrementujuci sa primarny kluc, ktory rastie spolu s datumom, t.j. neINSERTuju sa zaznamy so starsim DatumVypujcky
, nez je max(DatumVypujcky) GROUP BY Uzivatel
:SELECT * FROM Knihovna WHERE id IN (SELECT MAX(id) FROM Knihovna GROUP BY Uzivatel);
Zkus použít DISTINCT ON – prý to funguje i v MySQL.
Univerzálnějším řešením jsou Window Functions, ale ty v MySQL AFAIK nejsou.
Pokud není k dispozici ani jedno, jsou potřeba poměrně divoké poddotazy a spojování tabulek1. Pro srovnání:
[1] pokud máš málo dat a neřešíš rychlost, tak je to použitelné – jinak bych hledal spíš jiné řešení, možná i na úrovni aplikace nebo změny datového modelu…
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.