abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 20:22 | IT novinky

    Představena byla služba Raspberry Pi Connect usnadňující vzdálený grafický přístup k vašim Raspberry Pi z webového prohlížeče. Odkudkoli. Zdarma. Zatím v beta verzi. Detaily v dokumentaci.

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

    Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 0
    včera 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

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

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 2
    včera 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | Komunita

    Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.

    Fluttershy, yay! | Komentářů: 0
    včera 13:11 | IT novinky

    Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.

    Ladislav Hagara | Komentářů: 2
    6.5. 21:33 | Komunita

    Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.

    Ladislav Hagara | Komentářů: 5
    6.5. 21:11 | IT novinky

    Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.

    Ladislav Hagara | Komentářů: 1
    6.5. 17:55 | Nová verze

    AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (7%)
     (14%)
     (16%)
    Celkem 139 hlasů
     Komentářů: 10, poslední dnes 17:35
    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: 1192×
    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: 20 | 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: 20 | 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: 20 | 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: 20 | 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.