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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
včera 17:02 | Pozvánky

Přijďte si popovídat o open source obecně a openSUSE konkrétně s dalšími uživateli a vývojáři. Oslava nového vydání openSUSE Leap se uskuteční 16. prosince od 17:00 v nových prostorách firmy SUSE v Praze. K dispozici bude nějaké občerstvení a DVD pro ty, kdo je sbírají nebo ještě mají mechaniku. Po párty v kanceláři se bude pokračovat v některé z hospod v okolí.

Miška | Komentářů: 8
včera 14:55 | Zajímavý software

Byla vydána verze Alpha 1.0 otevřeného operačního systému pro chytré hodinky AsteroidOS. Podporovány jsou hodinky LG G Watch, LG G Watch Urbane, Asus ZenWatch 2 a Sony Smartwatch 3. Ukázka ovládání hodinek na YouTube. Jaroslav Řezník přednášel o AsteroidOS na chytrých hodinkách (videozáznam) na letošní konferenci OpenAlt.

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

Byly uvolněny zdrojové kódy známé rogue-like hry DoomRL. Počátky hry jsou v roce 2002. Je napsána ve FreePascalu a zdrojový kód je nyní k dispozici na GitHubu pod licencí GNU GPL 2.0. Autor pracuje na nové hře Jupiter Hell, která je moderním nástupcem DoomRL a na jejíž vývoj shání peníze prostřednictvím Kickstarteru.

Blaazen | Komentářů: 0
včera 13:15 | Pozvánky

Přijďte s námi oslavit vydání Fedory 25. Na programu budou přednášky o novinkách, diskuse, neřízený networking atd. Release Party se bude konat 16. prosince v prostorách společnosti Etnetera. Na party budou volně k dispozici také propagační materiály, nová DVD s Fedorou 25 a samozřejmě občerstvení. Přednášky budou probíhat v češtině. Pro více informací se můžete podívat na web MojeFedora.cz. Jen připomínám, že tentokrát jsme zavedli

… více »
frantisekz | Komentářů: 0
9.12. 16:38 | Komunita

Byly zveřejněny videozáznamy přednášek a workshopů z letošní konference OpenAlt konané 5. a 6. listopadu v Brně. K videozáznamům lze přistupovat ze stránky na SuperLectures nebo přes program konference, detaily o vybrané přednášce nebo workshopu a dále kliknutím na ikonku filmového pásu. Celkově bylo zpracováno 65 hodin z 89 přednášek a workshopů.

Ladislav Hagara | Komentářů: 0
9.12. 11:30 | Komunita

Bylo oznámeno, že bude proveden bezpečnostní audit zdrojových kódů open source softwaru pro implementaci virtuálních privátních sítí OpenVPN. Audit provede Matthew D. Green (blog), uznávaný kryptolog a profesor na Univerzitě Johnse Hopkinse. Auditována bude verze 2.4 (aktuálně RC 1, stabilní verze je 2.3.14). Audit bude financován společností Private Internet Access [reddit].

Ladislav Hagara | Komentářů: 4
9.12. 06:00 | Komunita

Na YouTube byl publikován Blender Institute Reel 2016, ani ne dvouminutový sestřih z filmů, které vznikly za posledních 10 let díky Blender Institutu. V institutu aktuálně pracují na novém filmu Agent 327. Dění kolem filmu lze sledovat na Blender Cloudu. Videoukázka Agenta 327 z června letošního roku na YouTube.

Ladislav Hagara | Komentářů: 0
9.12. 01:02 | Zajímavý článek

Minulý týden byly vydány verze 1.2.3 a 1.1.7 webového poštovního klienta Roundcube. V oznámení o vydání bylo zmíněno řešení bezpečnostního problému nalezeného společností RIPS a souvisejícího s voláním funkce mail() v PHP. Tento týden byly zveřejněny podrobnosti. Útočník mohl pomocí speciálně připraveného emailu spustit na serveru libovolný příkaz. Stejně, jak je popsáno v článku Exploit PHP’s mail() to get remote code execution z roku 2014.

Ladislav Hagara | Komentářů: 1
8.12. 16:00 | Nová verze

Byla vydána verze 0.98 svobodného nelineárního video editoru Pitivi. Z novinek lze zmínit například přizpůsobitelné klávesové zkratky. Videoukázka práce s nejnovější verzí Pitivi na YouTube.

Ladislav Hagara | Komentářů: 1
8.12. 15:00 | Zajímavý software

Stop motion je technika animace, při níž je reálný objekt mezi jednotlivými snímky ručně upravován a posouván o malé úseky, tak aby po spojení vyvolala animace dojem spojitosti. Jaký software lze pro stop motion použít na Linuxu? Článek na OMG! Ubuntu! představuje Heron Animation. Ten bohužel podporuje pouze webové kamery. Podpora digitálních zrcadlovek je začleněna například v programu qStopMotion.

Ladislav Hagara | Komentářů: 5
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (23%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 810 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: SQL - jak zobrazit stejny sloupec dvakrat jinak

5.12.2010 22:38 HonzaZ
SQL - jak zobrazit stejny sloupec dvakrat jinak
Přečteno: 764×
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: 12 | 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: 12 | 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: 12 | 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.