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

    Open source softwarový stack ROCm (Wikipedie) pro vývoj AI a HPC na GPU od AMD byl vydán ve verzi 7.0.0. Přidána byla podpora AMD Instinct MI355X a MI350X.

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

    Byla vydána nová verze 258 správce systému a služeb systemd (GitHub).

    Ladislav Hagara | Komentářů: 5
    dnes 15:11 | Nová verze

    Byla vydána Java 25 / JDK 25. Nových vlastností (JEP - JDK Enhancement Proposal) je 18. Jedná se o LTS verzi.

    Ladislav Hagara | Komentářů: 0
    dnes 14:44 | Humor

    Věra Pohlová před 26 lety: „Tyhle aféry každého jenom otravují. Já bych všechny ty internety a počítače zakázala“. Jde o odpověď na anketní otázku deníku Metro vydaného 17. září 1999 na téma zneužití údajů o sporožirových účtech klientů České spořitelny.

    Ladislav Hagara | Komentářů: 4
    dnes 11:33 | Zajímavý článek Ladislav Hagara | Komentářů: 0
    včera 21:44 | Nová verze

    Byl vydán Mozilla Firefox 143.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Nově se Firefox při ukončování anonymního režimu zeptá, zda chcete smazat stažené soubory. Dialog pro povolení přístupu ke kameře zobrazuje náhled. Obzvláště užitečné při přepínání mezi více kamerami. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 143 bude brzy k dispozici také na Flathubu a Snapcraftu.

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

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

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

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.2 (𝕏, Mastodon). Přehled novinek, vylepšení a nových efektů v poznámkách k vydání.

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

    Byla vydána nová verze 4.5 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    15.9. 21:33 | Nová verze

    Byla vydána verze 3.0 (Mastodon) nástroje pro záznam a sdílení terminálových sezení asciinema (GitHub). S novou verzí formátu záznamu asciicast v3, podporou live streamingu a především kompletním přepisem z Pythonu do Rustu.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (43%)
     (57%)
     (0%)
     (7%)
     (14%)
     (7%)
     (21%)
     (7%)
     (14%)
    Celkem 14 hlasů
     Komentářů: 1, poslední dnes 13:49
    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: 1207×
    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.