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 05:44 | Nová verze Ladislav Hagara | Komentářů: 1
    dnes 05:22 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti v knihovně pro Rust async-tar a jejích forcích tokio-tar, krata-tokio-tar a astral-tokio-tar. Jedná se o zranitelnost CVE-2025-62518 s CVSS 8.1. Nálezci je pojmenovali TARmageddon.

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

    AlmaLinux přinese s verzí 10.1 podporu btrfs. XFS bude stále jako výchozí filesystém, ale instalátor nabídne i btrfs. Více informací naleznete v oficiálním oznámení.

    Max | Komentářů: 0
    včera 22:33 | IT novinky

    Společnost OpenAI představila svůj vlastní webový prohlížeč ChatGPT Atlas. Zatím je k dispozici pouze na macOS.

    Ladislav Hagara | Komentářů: 0
    včera 14:33 | Nová verze

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 1
    včera 13:55 | IT novinky

    Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.

    Ladislav Hagara | Komentářů: 4
    včera 13:33 | IT novinky

    Na Humble Bundle běží akce Humble Tech Book Bundle: All Things Raspberry Pi by Raspberry Pi Press. Se slevou lze koupit elektronické knihy od nakladatelství Raspberry Pi Press a podpořit Raspberry Pi Press, Raspberry Pi Foundation North America nebo Humble.

    Ladislav Hagara | Komentářů: 0
    včera 11:44 | Humor

    Přidaný režim autonomního řízení vozidel Tesla Mad Max je dostupný pro vybrané zákazníky v programu EAP (Early Access Program). Nový režim je na silnici agresivnější, častěji mění pruhy a ne vždy dodržuje rychlostní limity. Agentura JPP spekuluje, že v Česku by se mohl nový režim namísto Mad Max jmenovat Mad Turek...

    karkar | Komentářů: 21
    včera 04:00 | Nová verze

    Byla vydána nová verze 9.18 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Nově také pro NanoPi R3S, R3S LTS, R76S a M5. Přehled novinek v poznámkách k vydání.

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

    bat, tj. vylepšený cat se zvýrazňováním syntaxe a integrací s gitem, byl vydán ve verzi 0.26.0.

    Ladislav Hagara | Komentářů: 1
    Jaké řešení používáte k vývoji / práci?
     (37%)
     (47%)
     (20%)
     (20%)
     (23%)
     (18%)
     (21%)
     (18%)
     (18%)
    Celkem 252 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Dotaz: MySQL trigger nad tabulkou nad kterou se spousti

    1.4.2010 13:39 sillySQL
    MySQL trigger nad tabulkou nad kterou se spousti
    Přečteno: 1218×
    Vytvořil jsem trigger, který nemůže vyvolat loop:
    CREATE TRIGGER tr_usernameSync AFTER UPDATE ON mailbox_base
      FOR EACH ROW BEGIN
        IF (NEW.username != CONCAT(NEW.local_part, '@', NEW.domain)) THEN BEGIN
          UPDATE `mailbox_base` SET `username` = CONCAT(NEW.local_part, '@', NEW.domain);
        END;
        END IF;
      END;
    Ale mysql mi při pokusu o update tabulky zahlásí "#1442 - Can't update table 'mailbox_base' in stored function/trigger because it is already used by statement which invoked this stored function/trigger."

    Zkoušel jsem to obejít tak, že jsem v triggeru volal proceduru na ten update, ale stejně to nefungovalo. Zkouším to rozchodit už nějakou tu hodinku. Mohl by mi někdo poradit co s tím?

    Odpovědi

    1.4.2010 13:51 Ondřej Kopka | skóre: 19 | blog: ondrejk
    Rozbalit Rozbalit vše Re: MySQL trigger nad tabulkou nad kterou se spousti
    hmm, ted strelim od boku, ale co takhle zkusit neco jako:
    CREATE TRIGGER tr_usernameSync AFTER UPDATE ON mailbox_base
      FOR EACH ROW BEGIN
        IF (NEW.username != CONCAT(NEW.local_part, '@', NEW.domain)) THEN BEGIN
          NEW.username = CONCAT(NEW.local_part, '@', NEW.domain);
        END;
        END IF;
      END;
    1.4.2010 13:54 sillySQL
    Rozbalit Rozbalit vše Re: MySQL trigger nad tabulkou nad kterou se spousti
    Jo, zrovna sem to chci napsat, jen tam musí být BEFORE.
    CREATE TRIGGER tr_usernameSync BEFORE UPDATE ON mailbox_base
      FOR EACH ROW BEGIN
        IF (NEW.username != CONCAT(NEW.local_part, '@', NEW.domain)) THEN BEGIN
          SET NEW.username = CONCAT(NEW.local_part, '@', NEW.domain);
        END;
        END IF;
      END;
    Tohle funguje. Proč ale nefunguje tamto?
    1.4.2010 13:56 Ondřej Kopka | skóre: 19 | blog: ondrejk
    Rozbalit Rozbalit vše Re: MySQL trigger nad tabulkou nad kterou se spousti
    rekl bych ze zavolanim update bys opet vyvolal ten trigger, coz by vedlo k zacykleni
    1.4.2010 13:58 Ondřej Kopka | skóre: 19 | blog: ondrejk
    Rozbalit Rozbalit vše Re: MySQL trigger nad tabulkou nad kterou se spousti
    tahle definice by mozna byla lepsi:
    CREATE TRIGGER tr_usernameSync BEFORE UPDATE ON mailbox_case FOR EACH ROW
    1.4.2010 13:55 Ondřej Kopka | skóre: 19 | blog: ondrejk
    Rozbalit Rozbalit vše Re: MySQL trigger nad tabulkou nad kterou se spousti
    pripadne se podivej sem: http://forge.mysql.com/wiki/Triggers, konkretne sekce No when conditions
    1.4.2010 17:08 sillySQL
    Rozbalit Rozbalit vše Re: MySQL trigger nad tabulkou nad kterou se spousti
    Uff, já si dával pozor aby nevznikl loop kvůli tomu update a už vůbec jsem si neuvědomil že ten samotný trigger vyvolává loop. :-)

    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.