Diskuze: Pivot table v MySQL
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 9 zpráv z 9.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Přijde mi dost nešikovné mít jako názvy sloupců jména, neznám tvůj Use Case, ale návrhově to vypadá jako chyba. Tabulky samozřejmě můžeš převést jen pomocí SQL dotazů, dá se totiž udělat něco jako:
INSERT INTO `tabulka` (sloupec1, sloupec 2) VALUES
(SELECT `sloupecX` AS `sloupec1`, `sloupecY` AS `sloupec2` FROM `tabulka2`)
Ahoj, no jedná se normálně o to co bych normálně udělal v accessu, a myslím tím křížovou tabulku. Možná to z té dolní tabulky není zřejmé, ale má se jednat už o konečný výstup. Co se týká jmen, tak těch může být víc, takže takovéhle řešení mi moc nepomůže. SQL dotaz by měl být podobný tomu níže:
SELECT
Obec,
SUM(CASE Jmeno WHEN 'Bob' THEN Cena ELSE 0 END) AS Bob,
SUM(CASE Jmeno WHEN 'Sue' THEN Cena ELSE 0 END) AS Sue
FROM zkouskapivot
GROUP BY Obec
nicméně pokud bych vždycky přidal nové jméno, které zde ještě nemám uvedený, tak bych musel přidat i nový řádek s podmínkou a ještě k tomu zjišťovat, které jméno přibylo, což bych potřeboval, aby bylo automatické.
Možná ti to připadá jako nešikovné, ale představ si, že ti manažer přikáže, abys mu vytiskl tabulku výkonnosti jednotlivých prodejců v jednotlivých městech (nebo třeba letech) a ty máš k dispozici normalizovaná data.
S novým jménem musíš hlavně přidat nový sloupec, proto se mi ta
tabulka nelíbí jedním
dotazem to určitě jde, ale bude dost hustý a nejsem v SQL tak sběhlý, abych
ho z fleku napsal. Určitě to v nejhorším můžeš vybrat buď pro uživatele
nebo pro město a jet to v cyklu.
Možná ti to připadá jako nešikovné, ale představ si, že ti manažer přikáže, abys mu vytiskl tabulku výkonnosti jednotlivých prodejců v jednotlivých městech a ty máš k dispozici normalizovaná data.....!
Zobrazeno 9 zpráv z 9.