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 18:22 | Nová verze

    Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.

    Ladislav Hagara | Komentářů: 2
    dnes 17:22 | Nová verze

    Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.

    Ladislav Hagara | Komentářů: 0
    dnes 13:33 | Pozvánky

    Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.

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

    Byla vydána Java 26 / JDK 26. Nových vlastností (JEP - JDK Enhancement Proposal) je 10. Odstraněno bylo Applet API.

    Ladislav Hagara | Komentářů: 10
    včera 23:55 | Nová verze

    Byla vydána nová verze 260 správce systému a služeb systemd (Wikipedie, GitHub). Odstraněna byla podpora skriptů System V. Aktualizovány byly závislosti. Minimální verze Linuxu z 5.4 na 5.10, OpenSSL z 1.1.0 na 3.0.0, Pythonu z 3.7.0 na 3.9.0…

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

    Byla vydána nová verze 5.1 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v poznámkách k vydání. Videopředstavení na YouTube.

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

    Bylo oznámeno vydání nové verze 8.1 "Hoare" kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Doprovodný příspěvek na blogu Khronosu rozebírá kódování a dekódování videa pomocí Vulkan Compute Shaders v FFmpeg.

    Ladislav Hagara | Komentářů: 12
    včera 04:33 | Zajímavý projekt

    Byl představen open-source a open-hardware prototyp nízkonákladového raketometu kategorie MANPADS, který byl sestaven z běžně dostupné elektroniky a komponent vytištěných na 3D tiskárně. Raketa využívá skládací stabilizační křidélka a canardovou stabilizaci aktivně řízenou palubním letovým počítačem ESP32, vybaveným inerciální měřicí jednotkou MPU6050 (gyroskop a akcelerometr). Přenosné odpalovací zařízení obsahuje GPS,

    … více »
    NUKE GAZA! 🎆 | Komentářů: 46
    16.3. 14:22 | IT novinky

    Vědci z univerzity La Sapienza v Římě vyvinuli systém, který dokáže identifikovat jednotlivce pouze na základě toho, jak narušují signály Wi-Fi. Autoři tuto novou technologii nazvali WhoFi. Na rozdíl od tradičních biometrických systémů, jako jsou skenery otisků prstů a rozpoznávání obličeje, nevyžaduje tato metoda přímý fyzický kontakt ani vizuální vstupy. WhoFi může také sledovat jednotlivce na větší ploše než kamera s pevnou polohou; stačí, je-li k dispozici Wi-Fi síť.

    Ladislav Hagara | Komentářů: 13
    16.3. 04:22 | Nová verze

    SuperTux (Wikipedie), tj. klasická 2D plošinovka inspirovaná sérií Super Mario, byl vydán v nové verzi 0.7.0. Videoukázka na YouTube. Hrát lze i ve webovém prohlížeči.

    Ladislav Hagara | Komentářů: 7
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (1%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1107 hlasů
     Komentářů: 27, poslední včera 19:26
    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: 897×
    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.