Portál AbcLinuxu, 13. května 2025 04:29
Řešení dotazu:
group by
, můžete mít ve výsledné sadě stejně jen sloupce, které jsou uvedené u group by
, nebo agregační funkce. A v order by
můžete mít jen to, co můžete mít ve výsledné sadě sloupců. MySQL vám dovolí do výsledné sady přidat i jiný sloupec, jeho hodnotu pak ale vybírá náhodně.
Ve vašem případě by asi bylo nejlepší udělat normalizaci databáze, a username a groupname rozdělit do dvou tabulek s vazbou 1:N. Pokud z nějakého důvodu musí struktura tabulek zůstat zachovaná, nezbývá asi než udělat spojení, ve kterém se ta tabulka objeví dvakrát:
SELECT username, (SELECT groupname FROM user AS u1 WHERE u1.username = u2.username ORDER BY groupname LIMIT 1) AS groupname FROM user AS u2 ORDER BY groupname;
username | groupname -------------------- user1 | sk8 user1 | sk5 user1 | sk2 user2 | sk1 select username, groupname from tabulka where groupname in ('sk1', 'sk5') group by username vrátí oba uživateleCo ovšem pokud budu chtít řadit podle groupname, které ale nechci zobrazovat (selectovat)? To potom musím použít 2 vnořené selecty (jeden řadí groupname, další vybírá všechno, ten nejvyšší vybírá některé sloupce z toho druhého)?
ORDER BY
. Ale lepší varianta je komentář č. 2 s použitím MIN()
, nenapadlo mne, že se dá MIN()
použít i pro texty.
SELECT username, MIN(groupname) FROM .. GROUP BY username; SELECT username, SUBSTRING_INDEX(GROUP_CONCAT(groupname ORDER BY groupname ASC SEPARATOR '#'),'#',1) FROM .. GROUP BY username;
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.