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 15:44 | Zajímavý software

    Asterinas (GitHub) je v Rustu napsané jádro operačního systému poskytující s jádrem Linux kompatibilní ABI. Vydána byla verze 0.18.0. První distribucí postavenou nad jádrem Asterinas je Asterinas NixOS. Nejedná se o oficiální projekt NixOS a nemá nic společného s NixOS Foundation.

    Ladislav Hagara | Komentářů: 1
    dnes 13:22 | Zajímavý článek

    Podrobně byla rozebrána kritická zranitelnost v nf_tables (CVE-2026-23111). Další lokální eskalace práv na Linuxu. V upstreamu byla zranitelnost již v únoru opravena. Ve zdrojovém kódu stačilo odstranit 1 vykřičník.

    Ladislav Hagara | Komentářů: 1
    dnes 12:11 | Nová verze

    Evropská komise (EK) nařídila americké společnosti Meta, že musí znovu umožnit bezplatný přístup konkurenčním obecně zaměřeným asistentům umělé inteligence (AI) k WhatsAppu a tento přístup musí zachovat až do ukončení antimonopolního šetření. Opatření je dočasné a má zabránit vážnému a nevratnému poškození konkurence na rychle rostoucím trhu s obecnými AI asistenty. Meta uvedla, že se proti rozhodnutí odvolá.

    Ladislav Hagara | Komentářů: 1
    dnes 11:44 | IT novinky

    Společnost Anthropic představila AI modely Claude Fable 5 a Claude Mythos 5. Claude Fable 5 je první model třídy Mythos určený pro běžné použití.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | Nová verze

    Byla vydána nová stabilní verze 3.24.0, tj. první z nové řady 3.24, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    dnes 03:33 | Komunita

    Na čem pracují vývojáři v Rustu napsaného mikrokernelového unixového operačního systému Redox OS (Wikipedie)? Byl publikován přehled vývoje za květen. Vypíchnout lze nový scheduler EEVDF nebo port desktopového prostředí Xfce na Redox OS.

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

    Upozornění pro uživatele Asahi Linuxu: Neaktualizujte macOS na verzi 27 Golden Gate! Apple změnil detekci spouštěcích oddílů. Po aktualizaci oddíl s Asahi Linuxem nevidí. Snad je to jenom chyba.

    Ladislav Hagara | Komentářů: 3
    včera 15:11 | Komunita

    Na webu konference Den IPv6, která se konala 4. června v Národní technické knihovně v pražských Dejvicích, jsou nyní k dispozici všechny prezentace (v PDF) a jejich videozáznamy. Organizátory konference byly i letos sdružení CESNET, CZ.NIC a NIX.CZ.

    VSladek | Komentářů: 0
    včera 13:11 | Nová verze

    Byla vydána nová verze 9.1.0 správce sbírky fotografií digiKam (Wikipedie). Přehled novinek i s náhledy v oficiálním oznámení (NEWS). Vypíchnout lze vylepšené vyhledávání nebo podporu Pixel Motion Photos. Nejnovější digiKam je ke stažení také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.

    Ladislav Hagara | Komentářů: 1
    včera 11:44 | Pozvánky

    Přihlaste svou přednášku na další ročník konference LinuxDays, který proběhne 3. a 4. října na FIT ČVUT v pražských Dejvicích. Příjem témat poběží do konce prázdnin, pak proběhne veřejné hlasování a následně sestavení programu.

    Petr Krčmář | Komentářů: 3
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (27%)
    Celkem 1867 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: trigger

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

    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.