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

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

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

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | IT novinky

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 4
    včera 11:44 | Komunita

    Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.

    Ladislav Hagara | Komentářů: 0
    včera 01:11 | IT novinky

    Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.

    Ladislav Hagara | Komentářů: 53
    29.4. 23:44 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.

    Ladislav Hagara | Komentářů: 4
    29.4. 17:44 | Nová verze

    Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    29.4. 04:44 | Komunita

    Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.

    Ladislav Hagara | Komentářů: 7
    29.4. 03:55 | Nová verze

    VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:22 | Nová verze

    Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách

    … více »
    Ladislav Hagara | Komentářů: 7
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (24%)
    Celkem 1467 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: SQL - jak zobrazit stejny sloupec dvakrat jinak

    5.12.2010 22:38 HonzaZ
    SQL - jak zobrazit stejny sloupec dvakrat jinak
    Přečteno: 898×
    Ahoj, mam databazi nejakych sportovnich vykonu (treba hod ostepem v metrech). Lidi mohli podat vice vykonu a rozlisit se mezi nimi da casem, kdy vykon podali.

    (pro orientaci: mam tabulky lidi, vykonu a zavodu)

    Zobrazit nejlepsi vykony vsech lidi je v pohode.

    Zobrazit nejlepsi vykony vsech lidi dosazene mezi lety 2005-2009 je taky v pohode.

    Ale jak do jedne tabulky zobrazim oboji? Tj. chci tabulku kde bude
    • jmeno cloveka
    • jeho nejlepsi vykon
    • jeho nejlepsi vykon v letech 2005-2009
    .

    Sedim nad tim uz hodiny. Ted prave studuji, jak v SQL napsat funkci, ktera mi to vyfiltruje, ale moc nadejne to nevidim.

    Neexistuje na tohle nejaky trik? Jde vubec tentyz sloupec s jinou hodnotou vypsat pouhym sql dotazem?

    Odpovědi

    6.12.2010 02:08 FooBar
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Epicky zjednodusene:
    SELECT
     clovek.clovek_id,
     clovek.jmeno,
     vykon_celkem.result,
     vykon_v_letech.result
    FROM
     clovek
    JOIN ( SELECT clovek_id, MAX(vykon) FROM vykon GROUP BY clovek_id ) AS vykon_celkem ON vykon_celkem.clovek_id = clovek.clovek_id
    JOIN ( SELECT clovek_id, MAX(vykon) FROM vykon WHERE leta BETWEEN 2005 AND 2009 GROUP BY clovek_id ) AS vykon_v_letech ON vykon_v_letech.clovek_id = clovek.clovek_id
    6.12.2010 08:45 HonzaZ
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Uf, diky moc! Odpoledne si to prostuduji
    6.12.2010 12:14 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Je ještě jedna možnost s použitím case.
    Select 
      clovek_id,
      clovek_jmeno,
      max(vykon) vykon,
      max(case when rok in (2005,2006,2007,2008,2009) then vykon else NULL end) vykon_v_letech
      from
       tabulka
      group by
       clovek_id, clovek_jmeno 
    
    finta je vodkoukana vocaď
    a bacha na hodnoty NULL, u nekterych db vraci aggregacni fce NULL, kdyz je ve sloupci NULL
    Nejsem blbý, jen se hloupě ptám
    6.12.2010 11:15 kuka
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    v Oracle 10 a vyssim:

    select clovek, vykon, case when rok between 2005 and 2009 then vykon else null end; vykon59

    vybere vykony podle zadanych kriterii do ruznych sloupcu. De facto jde jen o priznak, zda je vykon z daneho obdobi, ale pro nasledne grupovani je nejjednodussi tam tu hodnotu rovnou vlozit. Dale pak

    select max(vykon), max(vykon59) from dotaz_vyse group by clovek
    GeoRW avatar 6.12.2010 21:48 GeoRW | skóre: 13 | blog: GeoRW | Bratislava
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Pre Oracle:
    WITH max_vykony AS (SELECT /*+ materialize */ clovek_id, max(vykon) max1
                        FROM tabulka
                        GROUP BY clovek_id),
         max_vykony_05_09 AS (SELECT /*+ materialize */ clovek_id, max(vykon) max2
                              FROM tabulka
                              WHERE rok BETWEEN 2005 AND 2009
                              GROUP BY clovek_id)
    SELECT DISTINCT tab.clovek_id,
                    (SELECT max1
                     FROM max_vykony
                     WHERE clovek_id = tab.clovek_id),
                    (SELECT max2
                     FROM max_vykony
                     WHERE clovek_id = tab.clovek_id)
    FROM tabulka tab
    "This is to be taken with a grain of salt." ACBF - Advanced Comic Book Format
    GeoRW avatar 6.12.2010 21:52 GeoRW | skóre: 13 | blog: GeoRW | Bratislava
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Teda ak mas 3 samostatne tabulky tak:
    WITH max_vykony AS (SELECT /*+ materialize */ clovek_id, max(vykon) max1
                        FROM vykony
                        GROUP BY clovek_id),
         max_vykony_05_09 AS (SELECT /*+ materialize */ clovek_id, max(vykon) max2
                              FROM vykony
                              WHERE rok BETWEEN 2005 AND 2009
                              GROUP BY clovek_id)
    SELECT l.clovek_id,
           (SELECT max1
            FROM max_vykony
            WHERE clovek_id = l.clovek_id),
           (SELECT max2
            FROM max_vykony_05_09
            WHERE clovek_id = l.clovek_id)
    FROM lidi l
    "This is to be taken with a grain of salt." ACBF - Advanced Comic Book Format
    6.12.2010 22:16 kuka
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Na rozdil od reseni s case toto projde celou tabulku vicekrat a jeste to pak musi udelat join. To muze v zavislosti na velikosti tabulky dost vadit. Podstata problemu je takova, ze staci projit tabulku pouze jednou bez ohledu na to, za kolik casovych obdobi to chci sledovat, a tak by take melo vypadat optimalni reseni.
    GeoRW avatar 10.12.2010 10:39 GeoRW | skóre: 13 | blog: GeoRW | Bratislava
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    vtip je v tom, ze ten materialize hint ti vytvori agregovanu tabulku iba raz (resp. v tomto pripade 2 tabulky), takze to neprechadza viackrat; to riesenie s CASE sa da pouzit aj v tomto pripade, ze sa vytvori iba jedna agregovana tabulka (namiesto dvoch); zavisi potom, s akymi dalsimi tabulkami to budes este joinovat
    "This is to be taken with a grain of salt." ACBF - Advanced Comic Book Format
    10.12.2010 13:27 kuka
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Materializace je v tomto pripade nezadouci, protoze view se pouzije pouze jednou a bude to znamenat zbytecnou rezii navic. Hint materialize byva podle me zkusenosti optimalizatorem vzdy respektovan, takze i kdyz by asi mohl odhalit jeho nesmyslnost, nejspis se opravdu zbytecne vytvori dve temporary tabulky.

    Sam pises "respektive dve tabulky" a o to jde, zdrojova tabulka se bude prochazet dvakrat (typicky fullscan + sort). Pokud to nevidis rovnou (na prvni pohled jsou tam dva vnorene dotazy do te tabulky), zobraz si explain plan.
    8.12.2010 16:33 HonzaZ
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Diky vsem za odpovedi. Dnes se mi diky nim konecne podarilo vytvorit ten spravny dotaz! Radsi to sem davat nebudu, protoze je to prasarna - je to SELECT na stranku a trva 15 sekund. Dulezite je, ze to funguje. Diky
    11.12.2010 23:57 HonzaZ
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Mohu se zeptat jeste na jednu vec?

    Zdanlive je to uplne trivialni: Jak zobrazim prumer nejlepsich napr. 5 vykonu dosazenych v danem zavodu?

    Za nasledujicich podminek:
    • nemam prava vytvaret procedury
    • V tom clanku na rootu se pouzivalo tohle:

      SELECT AVG(vykon) FROM vykony WHERE zavod=88 AND vykon IN (
        SELECT vykon FROM vykony WHERE zavod=88 ORDER BY vykon DESC LIMIT 5
      );
      

      To je ok. Kdyz to ale napisu, tak se mi objevi hlaska:

      This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'
    (nemam moznost menit verzi databaze)

    Napada vas alternativni sql dotaz?
    okbob avatar 12.12.2010 07:39 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Ten článek se váže k PostgreSQL - jinak k Vašemu dotazu - řada věcí v MySQL prostě nejde vyřešit jedním dotazem.
    12.12.2010 12:39 depka | skóre: 20 | blog: eterity
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    vysledek vnoreneho dotazu vloz nejprve do docasne tabulky a z te pak vyber prumer
    12.12.2010 12:48 HonzaZ
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Dobry napad, zkousim to (create temporary table), ale na to asi taky nemam prava:

    ERROR 1044 (42000): Access denied for user ... to database ...
    13.12.2010 09:19 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Pokud umí Mysql cte, tak se dá možná použít cte, případně poddotaz:
    
    Select avg(vykon)
      from
      (
        Select vykon from vykony
          where zavod = 88 
          limit 5
      )dta
    
    
    
    
    Nejsem blbý, jen se hloupě ptám
    14.12.2010 22:12 HonzaZ
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    Uff.. Vubec zatim nevim, co tohle znamena.. Ale diky, zkusim to nastudovat
    15.12.2010 09:44 HonzaZ
    Rozbalit Rozbalit vše Re: SQL - jak zobrazit stejny sloupec dvakrat jinak
    aha, ted na to koukam z jineho stroje. Asi bug na abclinuxu nebo v konqueroru - v konqueroru 3.5 to zobrazuje diskuzi dost podivne (nejaky strasne dlouhy na prvni pohled SQL kod). toto vyzkousim, diky

    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.