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 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 0
dnes 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
dnes 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
včera 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

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

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
21.1. 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 6
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 10
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (11%)
 (2%)
 (73%)
 (4%)
 (11%)
Celkem 370 hlasů
 Komentářů: 25, poslední 21.1. 13:34
Rozcestník
Reklama

Dotaz: Jak transponovat tabulku v Mysql

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

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.