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 23:33 | Nová verze

Byla vydána nová stabilní verze 1.15 (1.15.1147.36) webového prohlížeče Vivaldi (Wikipedie). Z novinek lze zdůraznit možnost nastavení vlastního pozadí okna, přístup k záložkám z hlavního menu, lepší ovládatelnost v režimu celé obrazovky nebo vyřešení problémů se zvukem v HTML5. Nejnovější Vivaldi je postaveno na Chromiu 65.0.3325.183.

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

Node.js Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 10.0.0 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). Verze 10 se v říjnu stane novou aktivní LTS verzí. Podpora je plánována do dubna 2021.

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

Neal Cardwell ze společnosti Google oznámil zveřejnění verze 2.0 nástroje pro testování síťového stacku packetdrill. Jde o souhrnné vydání změn z interního vývoje od roku 2013.

Michal Kubeček | Komentářů: 0
včera 13:22 | Zajímavý software

Microsoft na svém blogu oznámil, že správce knihoven pro C++ Vcpkg (VC++ Packaging Tool) lze nově používat také na Linuxu a macOS. Aktuálně je pro Linux k dispozici více než 350 knihoven [reddit].

Ladislav Hagara | Komentářů: 1
včera 12:44 | Komunita

Byly zveřejněny exploity na Nintendo Switch a platformu Tegra X1: Fusée Gelée a ShofEL2. Jejich zneužití nelze zabránit softwarovou aktualizací. Na druhou stranu exploity umožní na Nintendo Switch snadno a rychle nainstalovat Linux, viz. ukázka na YouTube. Jenom je potřeba sáhnout na hardware.

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

Byla vydána verze 2.12.0 QEMU (Wikipedie). Přispělo 204 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn. Řešeny jsou také bezpečnostní chyby Meltdown a Spectre.

Ladislav Hagara | Komentářů: 7
včera 00:33 | Komunita

Google zveřejnil seznam 1 264 studentů přijatých do letošního Google Summer of Code. Přehled projektů, studentů, 212 organizací a mentorů je k dispozici na stránkách GSoC.

Ladislav Hagara | Komentářů: 0
24.4. 23:55 | Nová verze

Oracle vydal verzi 1.0 univerzálního virtuálního stroje GraalVM, který umožňuje běh programů napsaných v jazycích založených na JVM, JavaScript, LLVM bitcode a experimentálně Ruby, R a Python.

razor | Komentářů: 1
24.4. 01:22 | Zajímavý článek

Julia Evans pomocí svých kreslených obrázků proniká do Linuxu a informačních technologií. Vedle ucelených zinů publikuje také jednotlivé kreslené obrázky (RSS).

Ladislav Hagara | Komentářů: 5
23.4. 13:22 | Zajímavý software

Jordi Sanfeliu vydal verzi 1.0.0 svého unixového jádra Fiwix (Wikipedie) určeného také pro výuku operačních systémů. Dle článku na OSNews na něm začal pracovat již před více než dvaceti lety. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Stáhnout a vyzkoušet lze živou disketu nebo CD s GNU/Fiwixem.

Ladislav Hagara | Komentářů: 5
Používáte na serverech port knocking?
 (3%)
 (7%)
 (46%)
 (27%)
 (18%)
Celkem 380 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    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: 2245×
    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.