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 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

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

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 0
    17.7. 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 1
    17.7. 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 2
    17.7. 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 5
    16.7. 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 19
    16.7. 16:22 | IT novinky

    Vláda dne 16. července 2025 schválila návrh nového jednotného vizuálního stylu státní správy. Vytvořilo jej na základě veřejné soutěže studio Najbrt. Náklady na přípravu návrhu a metodiky činily tři miliony korun. Modernizovaný dvouocasý lev vychází z malého státního znaku. Vizuální styl doprovází originální písmo Czechia Sans.

    Ladislav Hagara | Komentářů: 26
    16.7. 15:33 | Upozornění

    Vyhledávač DuckDuckGo je podle webu DownDetector od 2:15 SELČ nedostupný. Opět fungovat začal na několik minut zhruba v 15:15. Další služby nesouvisející přímo s vyhledáváním, jako mapyAI asistent jsou dostupné. Pro některé dotazy během výpadku stále funguje zobrazování například textu z Wikipedie.

    bindiff | Komentářů: 8
    16.7. 13:33 | Bezpečnostní upozornění

    Více než 600 aplikací postavených na PHP frameworku Laravel je zranitelných vůči vzdálenému spuštění libovolného kódu. Útočníci mohou zneužít veřejně uniklé konfigurační klíče APP_KEY (např. z GitHubu). Z více než 260 000 APP_KEY získaných z GitHubu bylo ověřeno, že přes 600 aplikací je zranitelných. Zhruba 63 % úniků pochází z .env souborů, které často obsahují i další citlivé údaje (např. přístupové údaje k databázím nebo cloudovým službám).

    Ladislav Hagara | Komentářů: 5
    16.7. 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (3%)
     (0%)
     (1%)
     (4%)
    Celkem 410 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.