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 19:55 | Zajímavý článek

Byly zveřejněny (pdf) podrobnosti o kritické bezpečnostní chybě CVE-2017-12542 v HPE iLO 4 (Integrated Lights-Out), tj. v proprietárním řešení společnosti Hewlett Packard Enterprise pro vzdálenou správu jejich serverů. Bezpečnostní chyba zneužitelná k obejití autentizace a k vzdálenému spuštění libovolného kódu byla opravena již v květnu loňského roku ve verzi 2.53.

Ladislav Hagara | Komentářů: 7
včera 17:55 | Zajímavý projekt

CSIRT.CZ informuje o CTF (Capture the Flag) platformě ZSIS CTF s úlohami pro procvičování praktických dovedností z oblasti kybernetické bezpečnosti a upozorňuje na soutěž Google Capture the Flag 2018, kde je možné vyhrát zajímavé ceny.

Ladislav Hagara | Komentářů: 0
včera 17:00 | Komunita

Byly zveřejněny prezentace a videozáznamy přednášek z prvního československého setkání síťových operátorů CSNOG konaného 11. a 12. června v Brně a semináře IPv6 2018 uskutečněného 6. června v Praze.

Ladislav Hagara | Komentářů: 0
včera 16:11 | Komunita

Svobodný unixový operační systém FreeBSD slaví 25 let. Přesně před pětadvaceti lety, tj. 19. června 1993, byl vybrán název FreeBSD.

Ladislav Hagara | Komentářů: 0
včera 15:11 | Komunita

Oficiální YouTube kanál Blenderu je již několik dní blokován. Nadace Blender Foundation informuje, že od společnosti Google dostala šestistránkový návrh nové smlouvy (pdf). Zdá se, že podmínkou další spolupráce je zapnutí reklam na kanálu, tj. zpeněžení obsahu.

Ladislav Hagara | Komentářů: 26
včera 01:55 | Nová verze

Byla vydána verze 1.13 multiplatformního open source textového editoru Brackets (Wikipedie, GitHub). Přehled novinek v oficiálním oznámení a v poznámkách k vydání. Brackets je nově dostupný také jako balíček ve formátu Flatpak z oficiálního repozitáře Flathub.

Ladislav Hagara | Komentářů: 4
18.6. 18:44 | Komunita

Oficiální YouTube kanál Blenderu je již několik dní blokován. Důvody jsou zatím nejasné. Pravděpodobně chyba YouTube. Dění lze sledovat na Twitteru Tona Roosendaala.

Ladislav Hagara | Komentářů: 19
18.6. 17:55 | Zajímavý software

Na GitHubu byly pod open source licencí LLVM zveřejněny zdrojové kódy překladače programovacího jazyka C++ Zapcc vycházejícího z Clangu/LLVM. Překlad pomocí Zapccu je díky lepšímu kešování obvykle několikrát rychlejší než překlad pomocí Clangu. V březnu loňského roku byl vydán Zapcc ve verzi 1.0.

Ladislav Hagara | Komentářů: 0
18.6. 17:22 | Pozvánky

Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.

xkucf03 | Komentářů: 1
15.6. 22:44 | Zajímavý článek

Na blogu projektu NeoPG (GitHub), kryptografického softwaru vycházejícího z GnuPG, byly zveřejněny 4 příspěvky detailně popisující aktuální bezpečnostní problémy v GnuPG a souvisejících softwarových produktech. V prvním příspěvku je ukázáno, že je možné vytvořit zprávu, o které budou Earlybird, Evolution, Mutt nebo Outlook tvrdit, že jí dešifrovali a přitom ale zpráva vůbec zašifrována nebyla. V druhém příspěvku je popsána

… více »
Ladislav Hagara | Komentářů: 8
Jak čtete delší texty z webových stránek?
 (77%)
 (22%)
 (4%)
 (6%)
 (3%)
 (11%)
Celkem 221 hlasů
 Komentářů: 36, poslední 18.6. 21:16
    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: 785×
    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.