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í
×
    včera 17:11 | Komunita

    Je třetí sobota v září a proto vše nejlepší k dnešnímu Software Freedom Day (SFD, Wikipedie).

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

    Bogdan Ionescu rozběhl webový server na jednorázové elektronické cigaretě.

    Ladislav Hagara | Komentářů: 5
    19.9. 13:22 | Nová verze

    Byla vydána beta verze Ubuntu 25.10 s kódovým názvem Questing Quokka. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 25.10 mělo vyjít 9. října 2025.

    Ladislav Hagara | Komentářů: 0
    19.9. 12:55 | Nová verze

    Bola vydaná nová verzia 4.13 security platformy Wazuh. Prináša nový IT hygiene dashboard, hot reload dekodérov a pravidiel. Podrobnosti v poznámkách k vydaniu.

    peterm655 | Komentářů: 0
    19.9. 12:22 | IT novinky

    Americký výrobce čipů Nvidia investuje pět miliard dolarů (přes 100 miliard Kč) do konkurenta Intel, který se v poslední době potýká s vážnými problémy. Firmy to včera oznámily ve společné tiskové zprávě. Dohoda o investici zahrnuje spolupráci při vývoji čipů pro osobní počítače a datová centra. Akcie společnosti Intel na zprávu reagovaly výrazným růstem.

    Ladislav Hagara | Komentářů: 6
    19.9. 05:11 | Komunita

    Dlouholetý balíčkář KDE Jonathan Riddell končí. Jeho práci na KDE neon financovala firma Blue Systems, která ale končí (Clemens Tönnies, Jr., dědic jatek Tönnies Holding, ji už nebude sponzorovat), někteří vývojáři KDE se přesunuli k nově založené firmě Techpaladin. Pro Riddella se již nenašlo místo. Následovala debata o organizaci těchto firem, které zahraniční vývojáře nezaměstnávají, nýbrž najímají jako kontraktory (s příslušnými důsledky z pohledu pracovního práva).

    |🇵🇸 | Komentářů: 8
    19.9. 02:33 | Komunita

    V Amsterdamu probíhá Blender Conference 2025. Videozáznamy přednášek lze zhlédnout na YouTube. V úvodní keynote Ton Roosendaal oznámil, že k 1. lednu 2026 skončí jako chairman a CEO Blender Foundation. Tyto role převezme současný COO Blender Foundation Francesco Siddi.

    Ladislav Hagara | Komentářů: 0
    19.9. 02:22 | Zajímavý článek

    The Document Foundation, organizace zastřešující projekt LibreOffice a další aktivity, zveřejnila výroční zprávu za rok 2024.

    ZCR | Komentářů: 0
    18.9. 17:33 | Nová verze

    Byla vydána nová stabilní verze 7.6 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 140. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 1
    18.9. 16:22 | Nová verze

    Byla vydána verze 1.90.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (42%)
     (56%)
     (11%)
     (13%)
     (18%)
     (11%)
     (18%)
     (13%)
     (15%)
    Celkem 55 hlasů
     Komentářů: 7, poslední 19.9. 23:32
    Rozcestník

    Dotaz: MySQL 5.1 trigger before insert - podmínka

    12.5.2012 21:56 malda
    MySQL 5.1 trigger before insert - podmínka
    Přečteno: 436×
    Hezký večer všem,

    po dvou hodinách debugování už jsem celkem bezradný s následujícím problémem. Mám tabulku "majetek", do které vkládám jednotlivé záznamy, primární klíč je přes dva sloupce (cislo_inventarni a cislo_komponenty). Potřebuji triggerem zajistit, aby se při vložení záznamu provedla kontrola, zda-li již v databázi inventární číslo není - pokud je, tak se vyhledá max číslo komponenty a inkrementuje se, pokud není, tak se číslo komponenty nastaví na 0.

    Následující kód funguje pro vložení již existujícího inventárního čísla (inkrementace čísla komponenty), ale nefunguje pro "nový záznam" - tam kde by číslo komponenty mělo být 0. (Při vložení vyhodí chybu že "cislo_komponenty nesmí být null").

    Poradí někdo?

    Díky, malda

    Kód triggeru:
    BEGIN
       DECLARE max_cislo_komponenta INT;
    
       SELECT MAX(cislo_komponenta) INTO max_cislo_komponenta FROM majetek WHERE cislo_inventarni = NEW.cislo_inventarni;
    
       IF max_cislo_komponenta = NULL THEN
           SET NEW.cislo_komponenta = 0;
       ELSE
           SET NEW.cislo_komponenta = (max_cislo_komponenta + 1);
       END IF;
       
    END
    

    Řešení dotazu:


    Odpovědi

    Řešení 1× (malda (tazatel))
    12.5.2012 22:45 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: MySQL 5.1 trigger before insert - podmínka
    Že by:
    IF max_cislo_komponenta IS NULL THEN
    ?
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    12.5.2012 23:12 malda
    Rozbalit Rozbalit vše Re: MySQL 5.1 trigger before insert - podmínka
    Perfektní, problem solved. Jaká hloupá chyba :-) Díky moc!
    okbob avatar 13.5.2012 08:33 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: MySQL 5.1 trigger before insert - podmínka
    Jestli si nezamknete tabulku "majetek", tak tam mate paradni race condition.
    13.5.2012 11:26 malda
    Rozbalit Rozbalit vše Re: MySQL 5.1 trigger before insert - podmínka
    Tohle je pouze malá část kódu, určitě přidám transakci, bude tam toho ještě více.. Ale díky za upozornění :)

    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.