Portál AbcLinuxu, 13. května 2025 04:29

Dotaz: Order by + group by v mysql - jak na správné řazení

20.12.2010 15:11 cohanaen
Order by + group by v mysql - jak na správné řazení
Přečteno: 2347×
Odpovědět | Admin
Dobrý den. Mám jednoduchou tabulku se sloupci username a groupname. Jeden username může mít více groupname ale chci ho zobrazit jen jednou, proto provádím group by username. Jenže bych chtěl řadit řádky pomocí groupname, což může vracet pěkné nesmysly. Takže by bylo dobré řadit řádky podle nejmenší hodnoty groupname, která se nachází u každého username zvlášť a zobrazovat vždy jen jedno username. Jak tohoto docílit?

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

20.12.2010 15:24 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: Order by + group by v mysql - jak na správné řazení
Odpovědět | | Sbalit | Link | Blokovat | Admin
Pokud používáte 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;
20.12.2010 15:43 cohanaen
Rozbalit Rozbalit vše Re: Order by + group by v mysql - jak na správné řazení
No ve skutečnosti je to složitější v několika tabulkách a normalizované v 3NF. Takže MySQL nenabízí jinou možnost než použití vnořeného selectu? A co where, tam předpokládám stačí asi uvést podmínky, jak jsem tak zkoušel?
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živatele
Co 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)?
20.12.2010 15:53 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: Order by + group by v mysql - jak na správné řazení
Pokud ten sloupec nechcete ve výsledné sadě, můžete ten výraz dát jen do ORDER BY. Ale lepší varianta je komentář č. 2 s použitím MIN(), nenapadlo mne, že se dá MIN() použít i pro texty.
20.12.2010 15:37 blondak | skóre: 36 | blog: Blondak | Čáslav
Rozbalit Rozbalit vše Re: Order by + group by v mysql - jak na správné řazení
Odpovědět | | Sbalit | Link | Blokovat | Admin
Třeba takto...
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;
Každý problém ma své logické, snadno pochopitelné nesprávné řešení.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.