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 12:11 | IT novinky

    Open source router Turris Omnia NG Wired je v prodeji. Jedná se o Turris Omnia NG bez Wi-Fi. Je připraven pro zamontování do racku.

    Ladislav Hagara | Komentářů: 1
    dnes 11:44 | Pozvánky

    Sníh roztál a roztávají i bastlíři. Žene se na nás celá řada konferencí a seminářů technického rázu. Zajímá vás, jaké? Pak se připojte k 60. Virtuální Bastlírně, tedy k veřejné diskuzi bastlířů, techniků, učitelů i vědců. Jako vždy přijde na přetřes spousta novinek ze světa hardwaru, softwaru i bizáru. Na začátek lze očekávat hardwarová témata, tedy například nový KiCAD 10, nové akcelerátory LLM s nízkou spotřebou, nejvíce fosforeskující

    … více »
    bkralik | Komentářů: 1
    dnes 11:22 | Zajímavý článek

    IuRe (Iuridicum Remedium) v rámci programu Digitální svobody zveřejnila analýzu dopadů a efektivity systémů ověřování věku v digitálním prostoru, která srovnává implementace ověřování věku v Austrálii, Velké Británii a Evropské unii.

    |🇵🇸 | Komentářů: 0
    dnes 04:22 | Nová verze

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.3 (𝕏, Mastodon). Přehled novinek a vylepšení v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    dnes 03:55 | Nová verze

    Byla vydána nová verze 14.4 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 5
    včera 23:22 | Nová verze

    Databáze DuckDB (Wikipedie) byla vydána ve verzi 1.5.0. S kódovým názvem Variegata (husice rajská). Přináší řadu vylepšení, včetně nového ergonomičtějšího CLI klienta nebo podporu pro typ VARIANT a vestavěný typ GEOMETRY.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | Zajímavý software

    V pátek 6. a sobotu 7. března proběhl v pražském sídle Nejvyššího kontrolního úřadu (NKÚ) Hackathon veřejné správy 7.1. Publikovány byly vytvořené aplikace. V kategorii projektů rozvíjených z krajského kola zvítězil tým „Mackokládi“. Čtyři středoškoláci ze Dvora Králové uspěli s aplikací KompaZ. Jde o digitálního průvodce, který pomůže s rychlou a srozumitelnou orientací v životních i krizových situacích „krok za krokem“. Aplikace

    … více »
    Ladislav Hagara | Komentářů: 12
    včera 13:33 | Nová verze

    QGIS, svobodný desktopový GIS, byl vydán v nové hlavní verzi 4.0. Změny zahrnují několik nových analytických a editačních funkcí, rozšíření podpory 3D, více možností úprav uživatelského rozhraní či mnoho dalších zlepšení použitelnosti. Řada 3.44 má aktualizace plánovány do září.

    |🇵🇸 | Komentářů: 0
    včera 05:11 | Komunita

    Dan Blanchard vydal knihovnu pro Python chardet v nové verzi 7.0.0. S novou verzí byla knihovna přelicencována z LGPL na MIT. Souhlasili s tím všichni přispěvatelé? Dan Blanchard souhlasy vůbec neřešil. Zaúkoloval umělou inteligenci (Claude), aby knihovnu zcela přepsala a výslovně jí nařídil, aby nepoužila žádný LGPL kód. Dan Blanchard tvrdí, že se jedná o clean room design. Protistrana argumentuje, že umělá inteligence byla trénována

    … více »
    Ladislav Hagara | Komentářů: 23
    8.3. 18:44 | Komunita

    Andy Nguyen si na svou herní konzoli PlayStation 5 (PS5) pomocí exploitu Byepervisor nainstaloval Linux (Ubuntu). V Linuxu si spustil Steam a PS5 tak proměnil v Steam Machine. Na PS5 může hrát hry, které jsou vydané pouze pro PC a jsou na Steamu [Tom's Hardware].

    Ladislav Hagara | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (6%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 1047 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: MySQL GROUP BY a ORDER BY

    13.1.2012 08:01 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    MySQL GROUP BY a ORDER BY
    Přečteno: 966×
    V MySQL mám takovouto strukturu jako:
    otázka1               otázka2     otázka3
    |
    otázka1odpověď1                   otázka3odpověď1
    |
    otázka2odpověď2
    
    Otázky mají atribut top=0 a u odpovědí top=id otázky. SQL tabulka vypadí cca takto
    CREATE TABLE posts(id int(5) NOT NULL, top int(5) NOT NULL, title varchar(255), dateadd datetime NOT NULL, ......,PRIMARY KEY(id));
    
    Nevíte někdo jak získám výpis, který by obsahoval toto:
    otázka2odpověď2
    otázka2
    otázka3odpověď1
    
    tj. poslední odpověď, nebo samotnou otázku pokud nemá odpověď ale seřazenou podle data přidání sestupně. Zkoušel jsem něco jako:
    SELECT MAX(id), top,
    FROM posts
    GROUP BY top
    ORDER BY dateadd DESC
    
    Ale to vrací nesmyslné výsledky.

    Předem děkuji za odpovědi.

    Odpovědi

    13.1.2012 09:49 Kit
    Rozbalit Rozbalit vše Re: MySQL GROUP BY a ORDER BY
    Asi to není úplně správně, ale zdá se, že by to mohlo fungovat:
    SELECT posts.title, odp.title
      FROM posts LEFT JOIN posts AS odp ON odp.top=posts.id
      WHERE posts.top=0 GROUP BY posts.id;
    13.1.2012 10:58 l0gik | skóre: 22
    Rozbalit Rozbalit vše Re: MySQL GROUP BY a ORDER BY
    Na todle by se správně měli použít window function, který ale v nejsou. Správně by s měl pro každou otázku udělat subselect limit 1, ale to je strašný (pro malou db ale asi taky v pohodě)

    Kitovo řešení s group by IMHO fungovat nebude, mysql u group by u sloupců v group by neuvedenejch vrátí libovolnej řádek (zpravidla první, na kterej narazí)

    Zkusil bych něco ve stylu
    SELECT * FROM post LEFT JOIN 
    (
    odpovedi 
    INNER JOIN
    (SELECT top, MAX(date) date FROM  post WHERE top <> 0 GROUP BY top) grouped
    ON (grouped.top = odpovedi.top AND odpovedi.date = grouped.date)
    )
    ON (odpovedi.top = post.id)
    WHERE post.top = 0
    
    Smysl je: leftjoinu to na tabulku, kterou nejprve omezím pouze na poslední odpovědi z otázek.

    Má to jen tu chybu, že pokud tam budou dvě odpovědi ze stejnýho času, tak tam pro danou otázku budou řádky dvě. To se dá vyřešit různě: Např že k celýmu výsledku leftjoinu výsledek ještě jednou, s podmínkou že id otázky je stejný, ale id odpovědi větší a vrátim jen to, kde ten leftjoin se nepovede (tocelypodruhe.id is null) - tím vyloučím ty duplicitní odpovědi.

    Anebo se to dářešit přechodem na nějakou rozumější db, která umí window functions :-)
    13.1.2012 11:53 Kit
    Rozbalit Rozbalit vše Re: MySQL GROUP BY a ORDER BY
    Kitovo řešení s group by IMHO fungovat nebude, mysql u group by u sloupců v group by neuvedenejch vrátí libovolnej řádek (zpravidla první, na kterej narazí)
    Také jsem se divil, že mi to v SQLite funguje podle zadání. Místo libovolného řádku vrací poslední. V MySQL se mi to zkoušet nechtělo. Napsal jsem to jako nástin možného řešení. Musím přece tazateli nechat prostor pro jeho vlastní aktivitu, ne?
    13.1.2012 12:04 l0gik | skóre: 22
    Rozbalit Rozbalit vše Re: MySQL GROUP BY a ORDER BY
    Ten libovolný řádek samozřejmě není libovolný (ve smyslu fce random), ale řádek získaný dle nějakého nedokumentovaného a nezaručeného kritéria: MySQL vrací první na který narazí, SQLite tedy pravděpodobně poslední, na který narazí. - Takže pokud Ti někdy vznikne v db "díra", tak už to nemusí fungovat ni SQLite, protože pořadí fyzického uložení se bude od chronologického lišit.
    13.1.2012 12:28 Kit
    Rozbalit Rozbalit vše Re: MySQL GROUP BY a ORDER BY
    V SQLite jsou výstupní data vždy seřazena podle ID (pokud je nenecháš seřadit jinak), takže při běžném insertu s autoincrementem se ta díra nikdy nezaplní.

    Ale jinak s tebou souhlasím, mé řešení fungovat nemusí, protože neodpovídá specifikaci SQL a využívá vlastnost, která je dána implementací a není garantována.

    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.