Diskuze: Výpočet v jedné tabulce s vícero řádek
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 8 zpráv z 8.
//= 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.
Když očekáváš jednu hodnotu jako výsledek, k čemu tam je to "group by"?
Jen zkouška různých řešení, o které jsem se pokoušel.
Používej tlačítko odpovědět. Myslím, že tu chybu způsobuje právě to "group by"...
Bohužel to tak není. Když jsem s tím experimentoval tak jsem přišel na to, že první SUM(CenaProdejni) je v pořádku a vrací pouze jednu položku. Ale druhý sub select vrací více položek. A to bude ten problém.
Zkus si ten select nejdřív rozdělit. Zjistil bych ID faktury, která
vyhovuje podmínce (tady 224), v dalším kroku bych zjistil čísla dokladů,
kterých se tato faktura týká (tady 222 a 223) a pak bych dělal součty a
rozdíly cen těch dokladů...
Když ti toto bude fungovat, pak ba ses mohl pokusit ty dotazy nějak vcucnout
do jednoho
Ve finále by ten dotaz mohl vypadat třeba nějak takto
SELECT SUM(CenaProdejni - CenaNakupni) FROM TabPohybyZbozi
WHERE IDDoklad IN(SELECT IDOldDoklad FROM TabPohybyZbozi
WHERE IDDoklad IN (SELECT ID FROM TabDokladyZbozi
WHERE DatumUhrady = convert(datetime,'1.1.2017)))
Píšu to z hlavy, nezkoušel jsem to...
Díky za pomoc, nakonec jsem to vyřešil následovně:
SELECT cena_prodejni - cena_nakupni
FROM
(SELECT SUM(CenaProdejni) AS cena_prodejni, (SELECT SUM(CenaNakupni) from TabPohybyZbozi AS p WHERE p.IDDoklad = pohyby.IDOldDoklad AND p.IDZbozi = Pohyby.IDZbozi)
WHERE
doklady.DatumUhrady = convert(datetime,'1.1.2017') AND doklady.DruhPohybu = faktura
Zobrazeno 8 zpráv z 8.