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 14:33 | IT novinky

    Zástupci členských států EU se včera shodli na návrhu, který má bojovat proti šíření materiálů na internetu zobrazujících sexuální zneužívání dětí. Nařízení známé pod zkratkou CSAM a přezdívané chat control mělo množství kritiků a dlouho nebyla pro jeho schválení dostatečná podpora. Pro schválení byla potřeba kvalifikovaná většina a dánské předsednictví v Radě EU se snažilo dosáhnout kompromisu. Návrh nakonec po dlouhých týdnech

    … více »
    Ladislav Hagara | Komentářů: 2
    dnes 12:22 | Zajímavý software

    Britské herní studio Facepunch stojící za počítačovými hrami Garry's Mod a Rust uvolnilo svůj herní engine s&box (Wikipedie) jako open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Herní engine s&box je postavený nad proprietárním herním enginem Source 2 od společnosti Valve.

    Ladislav Hagara | Komentářů: 1
    dnes 04:55 | Komunita

    Vývoj programovacího jazyka Zig byl přesunut z GitHubu na Codeberg. Sponzoring na Every.

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

    Stejně jako GNOME i KDE Plasma končí s X11. KDE Plasma 6.8 poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 0
    včera 14:55 | IT novinky

    Poslanci Evropského parlamentu dnes vyzvali k výraznému zvýšení ochrany nezletilých na internetu, včetně zákazu vstupu na sociální sítě pro osoby mladší 16 let. Legislativně nezávazná zpráva, kterou dnes odsouhlasil Evropský parlament poměrem 493 hlasů pro ku 92 proti, kromě zavedení věkové hranice 16 let pro využívání sociálních sítí, platforem pro sdílení videí či společníků s umělou inteligencí (AI) vyzývá také k zákazu … více »

    Ladislav Hagara | Komentářů: 38
    včera 14:11 | Humor

    Doom v KiCadu nebo na osciloskopu? Žádný problém: KiDoom: Running DOOM on PCB Traces a ScopeDoom: DOOM on an Oscilloscope via Sound Card.

    Ladislav Hagara | Komentářů: 3
    včera 12:44 | Nová verze

    Po AlmaLinuxu byl v nové stabilní verzi 10.1 vydán také Rocky Linux. Přehled novinek v poznámkách k vydání.

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

    Open source reimplementace počítačových her Tomb Raider I a Tomb Raider II spolu s dalšími vylepšeními a opravami chyb TRX byla vydána ve verzi 1.0. Jedná se o sloučení projektů / enginů TR1X a TR2X do jednoho TRX. Videoukázka na YouTube.

    Ladislav Hagara | Komentářů: 1
    25.11. 17:00 | IT novinky

    Společnost Seznam.cz spouští konverzační nástroj založený na umělé inteligenci Seznam Asistent. Asistent využívá vlastní jazykový model SeLLMa a dočasně i komerční modely od OpenAI provozované v evropských datacentrech prostřednictvím Microsoft Azure. Dlouhodobým cílem Seznamu je provozovat Asistenta výhradně na interních jazykových modelech a ve vlastních datových centrech.

    Ladislav Hagara | Komentářů: 8
    25.11. 11:55 | Zajímavý software

    Software LibrePods osvobozuje bezdrátová sluchátka AirPods z ekosystému Applu. Exkluzivní funkce AirPods umožňuje využívat na Androidu a Linuxu. Díky zdokumentování proprietárního protokolu AAP (Apple Accessory Protocol).

    Ladislav Hagara | Komentářů: 1
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (46%)
     (19%)
     (18%)
     (22%)
     (15%)
     (23%)
     (16%)
     (18%)
    Celkem 409 hlasů
     Komentářů: 17, poslední 19.11. 21:57
    Rozcestník

    Dotaz: Jak transponovat tabulku v Mysql

    8.1.2009 10:54 zombik | skóre: 6
    Jak transponovat tabulku v Mysql
    Přečteno: 1478×

    Dobrý den,

    chtěl bych poprosit o radu, jak jednoduše transponovat tabulku v mysql. Sloupce na řádky a řádky na sloupce. Tabulka bude malinká. Těchto tabulek bude cca 20 a potřebuji to dát do jedné velké.

    příklad tabulky

    rokmesic chyby
    2008-01 0
    2008-02 10
    2008-03 5
    2008-04 3

    Předem děkuji

    Zdraví Jura

     

     

     

     

     

    Odpovědi

    8.1.2009 11:41 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql
    hledej "crosstab"
    Kuolema Kaikille (Paitsi Meille).
    8.1.2009 12:35 zombik | skóre: 6
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql

    Díval jsem se na ten crosstab, ale je to asi "klikací" záležitost (dev.mysql.com/doc/refman/5.0/en/connector-odbc-examples-tools-with-crystalreports.html). Nejde to udělat pomocí SQL ??

    Děkuji

    Jura

     

    9.1.2009 07:39 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql
    8.1.2009 16:48 Tomas
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql

    No moc nerozumím otázce. Přirovnal bych ji k otázce: "Jak pomocí vrtačky zatlouci hřebík ?".

    Pokud potřebujete data nějak zformátovat (transponovat) tak to udělejte v zobrazovací vrstvě.

    Pokud potřebujete tabulku, která poroste jak v počtu sloupců tak v počtu řádek tak udělejte datový model se dvěma dimenzemi:

    Např: dimeze1 = rokmesic ; dimenze2 = typ_chyby ;

    Tabulka CHYBY

    rokmesic typ_chyby pocet
    2008-01 1 0
    2008-01 2 3
    2008-02 1 10
    2008-02 2 8

    Tabulka TYP_CHYBY

    typ_chyby popis
    1 nevýznamná chyba
    2 kritická chyba

    Zobrazení by se pak dělalo například takto (neodladěný pseudo kod)

    print "<table> <tr><th> </th>" 
    sql1=connection.execute("select * from TYP_CHYBY order by typ_chyby") 
    while c=sql1.read do   
      print "<th>",c.popis,"</th>" 
    done  
    
    sql2=connection.execute("select * from CHYBY order by rokmesic, typ_chyby") 
    while c = sql2.read do   
     if c.typ_chyby=1 { print "<tr><td>",c.rokmesic,"</td>" }
     print "<td>",c.pocet,"</td>"   
     if c.typ_chyby=2 { print "</tr>" }  
    done  
    print "</table>"
    
    8.1.2009 21:36 Zombik
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql

    Zdravím,

    děkuji za pomoc, ale nejedna se o chyby, jak asi myslite. SQL dotazem ziskam uvedenou tabulku a tu potrebuji transponovat.

    Nejlepe pomoci SQL. Jde to ??

    Jura

    8.1.2009 23:44 Tomas
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql

    Ano jde to, s omezeními, ktará jsou daná přístupem v relačních DB. Je potřeba si uvědomit následující fakta:

    1. Všechny hodnoty sloupce ve výsledku SQL dotazu musí mít jeden stejný typ. Tudíž před transpozicí  musíte mít v rámci celého řádku jediný datový typ. Obvykle toto není splněno. Váš příklad (typy DATE, INT) toto nesplňuje. Implicitně splněno pokud je sloupec jen jeden.
    2. Počet sloupců výsledku dotazu musí být odvoditelný ještě před vyhodnocením dotazu. Tudíž i počet řádek před transpozicí musí být fixní. Tj lze transponovat jen tabulku u které víte před vytvořením SQL dotazu jaký je počet řádek.

    Ve Vašem případě by "transpozice" mohla vypadat takto:

    select * 
    from (select chyby as "2008-01" from CHYBY where rokmesic='2008-01') as S1
         ,(select chyby as "2008-02" from CHYBY where rokmesic='2008-02') as S2
         ,(select chyby as "2008-03" from CHYBY where rokmesic='2008-03') as S3
         ,(select chyby as "2008-04" from CHYBY where rokmesic='2008-04') as S4
    

    Je to ošklivé řešení vyplývající z toho že výsledek SELECT nevrací matici, ale množinu záznamů nad kterou transpozice není definována.

    9.1.2009 08:37 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql
    Je to ošklivé řešení vyplývající z toho že výsledek SELECT nevrací matici, ale množinu záznamů nad kterou transpozice není definována.
    Přesně tak. Tudíž bych si v případě potřeby nahrál tabulku do matice v nějakém jiném jazyce (např. Perl) a transponoval tu.
    In Ada the typical infinite loop would normally be terminated by detonation.
    9.1.2009 09:01 zombik | skóre: 6
    Rozbalit Rozbalit vše Re: Jak transponovat tabulku v Mysql

    Děkuji za pomoc. Počet řadku a sloupců bude mít tabulka fixní a slopec rokmesic bude zahlavi transponovane tabulky. Jde jen o prevedeni sloupce chyby na radek.

    Ještě jednou moc děkuji

    Jura

     

    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.