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 16:44 | Komunita

    Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.

    Ladislav Hagara | Komentářů: 3
    včera 14:55 | Humor

    McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.

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

    Byla vydána (𝕏) červnová aktualizace aneb nová verze 1.102 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.102 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    10.7. 21:00 | Bezpečnostní upozornění

    Byla vydána nová verze 2.4.64 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 8 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 4
    10.7. 15:22 | Nová verze

    Společnost xAI na síti 𝕏 představila Grok 4, tj. novou verzi svého AI LLM modelu Grok.

    Ladislav Hagara | Komentářů: 11
    10.7. 12:55 | Bezpečnostní upozornění

    Ministerstvo vnitra odhalilo závažný kyberincident v IT systému resortu. Systém, do kterého se dostal útočník bez oprávnění, byl odpojen a nedošlo k odcizení dat [𝕏].

    Ladislav Hagara | Komentářů: 16
    10.7. 11:55 | Humor

    Před rokem byla streamovací služba HBO Max přejmenována na Max. Dle managementu slovo HBO v názvu nebylo důležité. Včera byl Max přejmenován zpět na HBO Max. Kolik milionů dolarů to stálo? 😂

    Ladislav Hagara | Komentářů: 12
    10.7. 02:11 | Nová verze

    Byla vydána nová major verze 8.0.0 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata (Wikipedie). Přehled novinek v oficiálním oznámení a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    10.7. 01:11 | Nová verze

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.4. Přehled novinek s náhledy a videi v oznámení na blogu.

    Ladislav Hagara | Komentářů: 1
    10.7. 00:11 | IT novinky

    Instituce státní správy nebudou smět využívat produkty, aplikace, řešení, webové stránky a webové služby poskytované čínskou společností DeepSeek. Na doporučení Národního úřadu pro kybernetickou a informační bezpečnost rozhodla o jejich zákazu vláda Petra Fialy na jednání ve středu 9. července 2025.

    Ladislav Hagara | Komentářů: 8
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 385 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: trigger

    28.1.2009 01:30 johny
    trigger
    Přečteno: 441×

    Ahoj vsem,  poteboval bych poresit jednu vec.

    Mam tabulku se zaznamy tvorenymi polozkami x a y, ktera vypada nejak takhle

    CREATE TABLE "tab" (

    x varchar(64);

    y varchar(64);

    created DATETIME;

    last DATETIME;

    UNIQUE ( x, y);

    )

    Krome polozek x a y obsahuje tabulka i dva casove udaje - kdy byl zaznam porizen a kdy byl naposledy kontrolovan.

    Samotne zaznamy by mely byt unikatni, nemenne, pri pokusu o vlozeni stejneho zaznamu by melo dojit jen k prepsani znacky 'last'.

    Myslim, ze to neni az tak neobvyykla uloha. Je mozne zajistit preklopeni pokusu o vlozeni na update znacky last pomoci triggeru? Primarne bych to chtel v sqlite, ale nebranim se ani reseni v jinych DB.

     

    Odpovědi

    28.1.2009 07:35 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: trigger

    ano, jde to. A často se to tak dělá.

    sqlite:  dokumentace a příklady

    Kuolema Kaikille (Paitsi Meille).
    28.1.2009 12:55 johny
    Rozbalit Rozbalit vše Re: trigger

    A mohl bych vedet jak?

    Googlit jsem samozrejme zkousel, zkousel jsem par desitek pokusu, ale porad ne a ne prijit na to jak :(

    28.1.2009 14:36 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: trigger

    snadno

    -- Script started
    CREATE TABLE tab
    (
    x VARCHAR2(64),
    y VARCHAR2(64),
    created DATETIME,
    updated DATETIME,
    unique(x, y)
    );
    -- No error
    --
    CREATE TRIGGER t_tab_insert
        AFTER INSERT ON tab
        FOR EACH ROW
    BEGIN
        UPDATE tab SET created = DATETIME('NOW')
             WHERE x = new.x
         AND y = new.y;
    END;
    -- No error
    --
    CREATE TRIGGER t_tab_update
        AFTER UPDATE OF x, y ON tab
        FOR EACH ROW
    BEGIN
        UPDATE tab SET updated = DATETIME('NOW')
             WHERE x = new.x
         AND y = new.y;
    END;
    -- No error
    --
    insert into tab values ('1', '1', null, null);
    -- No error
    --
    insert into tab values ('1', '2', null, null);
    -- No error
    --
    select * from tab;
    -- No error
    -- x   y   created             updated
    -- -   -   ------------------- -------
    -- 1   1   2009-01-28 13:34:54 {null}
    -- 1   2   2009-01-28 13:34:55 {null}

    update tab set x = '2';
    -- No error
    --
    select * from tab;
    -- No error
    -- x   y   created             updated
    -- -   -   ------------------- -------
    -- 2   1   2009-01-28 13:34:54 2009-01-28 13:35:36
    -- 2   2   2009-01-28 13:34:55 2009-01-28 13:35:36

    -- Script finished

    Jiné DB neš sqlite mají pochopitelně jiné možnosti. Takže by to šlo udělat jendím triggerem 9IF UPDATING... apod.) ale fakt bude lepší, kdyby sis přešetl nějakou SQL příručku a dokumentaci k tvé DB.

    Kuolema Kaikille (Paitsi Meille).
    28.1.2009 14:37 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: trigger

    kurvafix, ten editor mne zabje...

    Kuolema Kaikille (Paitsi Meille).
    28.1.2009 16:54 johny
    Rozbalit Rozbalit vše Re: trigger

    Diky,

      tohle jsem taky zkousel, ale me jde o to, aby kdyz udelam znovu insert toho sameho, tak abych misto hlasky o poruseni omezeni docilil ten update.

    sqlite> insert into tab values ('1', '1', null, null);
    sqlite> insert into tab values ('1', '2', null, null);
    sqlite> insert into tab values ('1', '1', null, null);
    SQL error: columns x, y are not unique
     

    28.1.2009 21:47 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: trigger
    jak rikam, cti dokumentaci ;)

    ON CONFLICT REPLACE http://www.sqlite.org/lang_conflict.html
    Kuolema Kaikille (Paitsi Meille).
    29.1.2009 08:48 johny
    Rozbalit Rozbalit vše Re: trigger

    Dokumentaci mam prectenou horem dolem, jinak bych se neptal :)

    U toho REPLACE se rika, ze pre-existing rows that are causing the constraint violation are removed. To mi ale vadi, protoze tim prijdu o puvodni hodnotu sloupce created. To uz mi prislo zajimavejsi to IGNORE ale s tim jsem taky niceho nedosahl.

    Idealni by bylo, kdy k tomu ON CONFLICT sla pripojit vlastni procedura nebo by sla odchytit ta chybova vyjimka, ale to tady nejde. Napadlo me i odstranit ten constraint a delat ho rucne v triggeru i kdyz to mi neprijde jako moc efektivni. Myslel jsem, ze by to mohla byt pomerne casta uloha a zajimalo me, jestli na to neni nejaka znama finta, at uz v sqline nebo jine DB.

     

     

    29.1.2009 14:40 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: trigger
    V jiných DB to jde snadno (Oracle, a asi i PostgreSQL), ale sqlite je prostě jednodušší.

    Tak to udělej jinak. Udělěj si k TAB ještě třeba TAB_AUDIT a k danému PK tam triggerem budeš házet záznamy. Hehe, třeba se k tomu tak nějak dostaneme...

    CREATE TABLE tab
    (
    x VARCHAR2(64),
    y VARCHAR2(64),
    unique(x, y) on conflict replace
    );
    
    create table tab_audit
    (
    x VARCHAR2(64),
    y VARCHAR2(64),
    dml_action varchar2(10),
    stamp DATETIME
    );
    
    CREATE TRIGGER t_tab_insert
        AFTER INSERT ON tab
        FOR EACH ROW
    BEGIN
        insert into tab_audit 
        values (new.x, new.y, 'INSERT', DATETIME('NOW'));
    END;
    
    CREATE TRIGGER t_tab_update
        AFTER UPDATE OF x, y ON tab
        FOR EACH ROW
    BEGIN
        insert into tab_audit 
        values (new.x, new.y, 'UPDATE', DATETIME('NOW'));
    END;
    
    insert into tab values ('1', '1');
    insert into tab values ('1', '1');
    insert into tab values ('1', '2');
    select * from tab;
    select * from tab_audit;
    
    update tab set x = '2';
    select * from tab;
    select * from tab_audit;
    

    Aktuální stav dohledáš (outer) joinem, historii selektem. Jo, a nejsou tam indexy.

    Anebo to ošetři v klientský aplikaci jako UPSERT.
    Kuolema Kaikille (Paitsi Meille).
    29.1.2009 11:14 qvaq
    Rozbalit Rozbalit vše Re: trigger

    V Oracle jde toto pomoci merge (tedy neni to uz insert) - definuje se co se ma stat pokud zaznam existuje (typicky update) a co pokud neexistuje (typicky insert). Samozrejme triggerem by to slo i v Oracle.

    Dovedu si predstavit, ze se takovy trigger muze nekdy hodit, nicmene mam s tim dost spatne zkusenosti. Pokud insert uz neni ve skutecnosti insert, muze to nekdy byt docela matouci, takze tam kde to jde preferuji explicitni reseni (zmineny merge nebo select a podle vysledku insert/update) - kazdemu je pak z kodu jasne, co se vlastne v tabulce stane.

    29.1.2009 14:13 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: trigger
    já bych triggery nejradši zrušil úplně ;)
    Kuolema Kaikille (Paitsi Meille).

    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.