abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 2
    včera 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 1
    14.5. 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 1
    14.5. 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 23
    14.5. 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    14.5. 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    14.5. 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    13.5. 21:22 | Bezpečnostní upozornění

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 12
    13.5. 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1634 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    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: 2389×
    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:


    Odpovědi

    20.12.2010 15:24 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Order by + group by v mysql - jak na správné řazení
    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: 67 | 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í
    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   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.