Diskuze: spočítání stejných záznamů v jednom řádku
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 10 zpráv z 10.
//= 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.
Ahoj, k tomu, co potřebuješ se používá GROUP BY.
SELECT hodnota, SUM(nazev) FROM tabulka WHERE podminka GROUP BY hodnota";
Ty ale nechceš sčítat hodnoty, takže místo SUM bude COUNT
To co radis ale scita (at uz hodnoty, nebo vyskyty) ve sloupcich. Jestli dotaz chapu dobre, tak slecna/pani potrebuje scitat hodnoty v ramci radku. Aktualne (sedim si mozna na vedeni) me napada reseni pres union select je to ale desne neprehledne, blbe na udrzbu a neskutecne neefektivni ...
Zajímavé, v SQL jsem toto zatím řešit nepotřeboval. Ale od jinud. Když neexistovala rozumná funkce pro 'sčítání' v řádku, tak jsem používal transponování tabulky/řádku tj. prohození x->y. Z řádků se staly sloupce a naopak. Zkus se mrknout na funkce PIVOT() UNPIVOT().
Ahoj v případě celých čísel stačí sečíst výpis tabulek:
SELECT col1 + col2 AS total FROM table
WHERE id = 1
V případě řetězců by se dalo použít něco takového:
// Celkem ano
SELECT IF(col1 = 'yes', 1, 0) + IF(col2 = 'yes', 1, 0) AS totalYes FROM table
WHERE id = 1
// Celkem ne
SELECT IF(col1 = 'no', 1, 0) + IF(col2 = 'no', 1, 0) AS totalNo FROM table
WHERE id = 1
Uživatel sítě Chápu správně, že by se toto dalo použít na nějaké dynamickém sloupci? Tj. mít to k dispozici rovnou pro celou tabulku a ne to vždy nasčítávat pro jedno id?
Nevim, jak moderni db, ale ma predstava o tabulce je pevny pocet sloupcu. Dynamiku ma smysl resit v pripade, ze casem pridas dalsi a jsi liny opravit sql dotazy.
Možná jsem se nepřesně vyjádřil. Měl jsem na mysli sloupec, který tam bude vždy, ale jeho obsah bude dán výpočtem .. tj. bude se aktualizovat dynamicky na základě změny obsahu sloupců, na nichž závisí.
Ano, pokud chápu správně jak to myslíš, tak každé sečtení se provede v rámci řádku.
Provedeš-li podobný SQL příkaz na tabulku o dvou řádcích bez definice řádku, tak výpis bude obsahovat 2 řádky.
Zobrazeno 10 zpráv z 10.