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í
×
    dnes 01:33 | IT novinky

    IuRe (Iuridicum Remedium) vyhlásila Ceny Velkého bratra za rok 2025. Slídily roku jsou automobilka Volkswagen, Meta a česká Ministerstva vnitra a průmyslu a obchodu. Autorem Výroku Velkého bratra je dánský ministr spravedlnosti zpochybňující právo na šifrovanou komunikaci. Naopak Pozitivní cenu získali studenti Masarykovy univerzity za odpor proti nucení do používaní aplikace ISIC.

    |🇵🇸 | Komentářů: 0
    včera 21:11 | Nová verze

    Po osmi měsících vývoje byla vydána nová verze 0.16.0 programovacího jazyka Zig (Codeberg, Wikipedie). Přispělo 244 vývojářů. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 18:22 | Bezpečnostní upozornění

    Nejnovější X.Org X server 21.1.22 a Xwayland 24.1.10 řeší 5 bezpečnostních chyb: CVE-2026-33999, CVE-2026-34000, CVE-2026-34001, CVE-2026-34002 a CVE-2026-34003.

    Ladislav Hagara | Komentářů: 0
    včera 18:00 | Nová verze

    Po roce vývoje od vydání verze 1.28.0 byla vydána nová stabilní verze 1.30.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.30.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2026-04-13. Přehled novinek poznámkách k vydání. Nově ve výchozím nastavení příkaz sudo vyžaduje heslo.

    Ladislav Hagara | Komentářů: 0
    včera 11:22 | Nová verze

    Společnost Blackmagic Design oznámila vydání verze 21 svého proprietárního softwaru pro editování videí a korekci barev DaVinci Resolve běžícího také na Linuxu. Z novinek je nutno vypíchnout možnost editování fotografií. Základní verze DaVinci Resolve je k dispozici zdarma. Plnou verzi DaVinci Resolve Studio lze koupit za 295 dolarů.

    Ladislav Hagara | Komentářů: 9
    včera 05:00 | Nová verze

    Multipatformní renderovací jádro webového prohlížeče Servo je na crates.io. S vydáním verze 0.1.0 (LTS).

    Ladislav Hagara | Komentářů: 0
    13.4. 23:33 | Komunita

    Nadace FreeBSD Foundation před týdnem oznámila projekt Laptop Integration Testing. Vyzvala dobrovolníky, aby pomocí nástroje otestovali podporu FreeBSD na svých zařízeních a výsledky odeslali vývojářům. Vznikla stránka Nejlepší notebooky pro FreeBSD.

    Ladislav Hagara | Komentářů: 5
    13.4. 22:22 | IT novinky

    Na začátku srpna vstoupí v účinnost nová evropská pravidla transparentnosti pro umělou inteligenci (AI). Zavádějí povinnost jakýkoli AI obsah označit, informovat o takzvaných deepfakes a upozornit uživatele, že komunikuje s umělou inteligencí. Cílem opatření je omezit šíření manipulativního či klamavého obsahu, zvýšit důvěru v digitální prostředí a chránit uživatele.

    Ladislav Hagara | Komentářů: 8
    13.4. 10:22 | Humor

    Connor Byrne z USA používal pro přihlašování na svůj iPhone 13 s iOS 18 heslo obsahující háček. Po aktualizaci na iOS 26.4 se už ale do telefonu nepřihlásí. Při přihlašování nelze tento háček zadat. Apple jej prostě odstranil [The Register].

    Ladislav Hagara | Komentářů: 41
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1325 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: 2386×
    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.