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 17:22 | Nová verze

    Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 0
    dnes 03:44 | Nová verze

    Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).

    Ladislav Hagara | Komentářů: 0
    dnes 02:11 | Komunita

    Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.

    Ladislav Hagara | Komentářů: 0
    dnes 00:44 | Nová verze

    Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    dnes 00:22 | Nová verze

    D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    včera 23:22 | Nová verze

    Bylo vydáno Eclipse IDE 2026-03 aneb Eclipse 4.39. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 4
    včera 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 10
    včera 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 31
    včera 09:33 | IT novinky

    Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.

    Ladislav Hagara | Komentářů: 0
    včera 00:22 | Nová verze

    Byla vydána betaverze Fedora Linuxu 44 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 14. dubna.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 1055 hlasů
     Komentářů: 26, poslední dnes 08:56
    Rozcestník

    Dotaz: Firebird, SUM a zmena hodnoty

    13.9.2017 23:04 Tom
    Firebird, SUM a zmena hodnoty
    Přečteno: 1536×
    Dobry den, chtel bych pozadat o radu se selectem v DB Firebird. Je mozne na zaklade hodnoty v jednom sloupci zmenit hodnotu v druhem sloupci a nasledne spocitat SUM toho druheho sloupce? Priklad:
    popis    hodnota
    
    minus    10
    bbb      -30
    plus     50
    cccc     2
    minus    25
    
    potreboval bych vybrat pouze radky ktere obsahuji v prvnim sloupci "plus" nebo "minus", tam kde je "minus" tak zmenit znamenko v sloupci hodnota a udelat SUM(hodnota). Takze -10+50-25

    Normalni SUM delam takto:
    select sum(t1.hodnota)
    from tabulka t1
    where t1.popis like 'plus' or t1.popis like 'minus'
    
    Jde nejak doplnit ten select a dostat pozadovany vysledek?

    Dekuji. Tom

    Řešení dotazu:


    Odpovědi

    13.9.2017 23:42 zdenek
    Rozbalit Rozbalit vše Re: Firebird, SUM a zmena hodnoty
    select sum(iif(t1.popis = 'minus', t1.hodnota * -1, t1.hodnota)) from tabulka t1
    14.9.2017 01:30 Tom
    Rozbalit Rozbalit vše Re: Firebird, SUM a zmena hodnoty
    To je ono, dekuji. Tom
    14.9.2017 07:17 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Firebird, SUM a zmena hodnoty

    Tohle tam přičte i druhý a čtvrtý řádek, takže byste buď musel přidat

      ... where t.popis in ('plus','minus')
    

    nebo místo iif použít case:

      case T1.POPIS when 'plus' then T1.HODNOTA when 'minus' then -T1.HODNOTA else 0 end
    

    A nebo obecněji

      create table NAME2COEF (
        NAME varchar(16) primary key,
        COEF integer
      );
      insert into NAME2COEF values ('plus', 1);
      insert into NAME2COEF values ('minus', -1);
    
      select sum(NC.COEF * T.HODNOTA) from
        TABULKA T inner join NAME2COEF NC on NC.NAME = T.POPIS;
    

    Nakonec ale stejně často nejjednodudšší bude udělat dva obyčejné selecty a odečíst výsledky.

    22.9.2017 11:53 ehmmm
    Rozbalit Rozbalit vše Re: Firebird, SUM a zmena hodnoty
    Se zacatkem v podstate souhlas. Za predpokladu, ze by t.popis byl indexovany, tak bych samozrejme preferoval ten where.

    Tabulka NAME2COEF je z pedagogickeho duvodu dobra, ale v tomto pripade to je nejspis kanon na vrabce.

    A celkem nesouhlas s posledni poznamkou se dvema selecty. Proc se ptat serveru dvakrat, kdyz to muzu vyridit jednim dotazem? Podle me ty dva jednodussi dotazy nikdy nebudou efektivnejsi nez jeden slozitejsi. (?)
    22.9.2017 16:07 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Firebird, SUM a zmena hodnoty

    Tohle je prostě potřeba řešit případ od případu a hlavně s ohledem nejen na aktuální situaci, ale i na výhled do budoucna. Pokud mám jistotu, že ty váhy budou na věky věků vždy jen tyhle dvě, tak to klidně udělám kterýmkoli z těch jednodušších postupů. Ale pokud bude riziko, že jich časem bude víc nebo že se dokonce budou měnit, jdu do referenční tabulky. Tohle je problém podobných dotazů v poradně, protože optimální řešení často závisí na informacích, které nemáme - a někdy je v daném okamžiku nemá ani tazatel.

    Stejně je to i s tou závěrečnou poznámkou. Teoreticky je "jeden dotaz" efektivnější než "dva dotazy", ale praxe může být často jiná, pokud se kvůli tomu, aby to byl "jen jeden dotaz" budou dělat moc velké vylomeniny. Nemluvě o tom, že dva selecty nemusejí nutně znamenat dva samostatné dotazy klienta na server.

    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.