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í
×
15.6. 22:44 | Zajímavý článek

Na blogu projektu NeoPG (GitHub), kryptografického softwaru vycházejícího z GnuPG, byly zveřejněny 4 příspěvky detailně popisující aktuální bezpečnostní problémy v GnuPG a souvisejících softwarových produktech. V prvním příspěvku je ukázáno, že je možné vytvořit zprávu, o které budou Earlybird, Evolution, Mutt nebo Outlook tvrdit, že jí dešifrovali a přitom ale zpráva vůbec zašifrována nebyla. V druhém příspěvku je popsána

… více »
Ladislav Hagara | Komentářů: 5
15.6. 13:00 | Komunita

GamingOnLinux informuje, že počítačová hra Track Mania Nations Forever (Steam, Wikipedie) pro Windows je nově dostupná také jako snap. Stejně jako v případě winepaku a Flatpaku se k běhu hry používá překladová vrstva Wine.

Ladislav Hagara | Komentářů: 12
14.6. 15:12 | Komunita

Tradiční setkání příznivců operačního systému Linux pod názvem Linux párty Teplice se bude konat v pátek 15. 6. 2018 v Hospůdce u černé Kočky od 18:00 hodin. Setkají se zde pamětníci příkazové řádky, vítáni jsou však i začínající uživatelé.

František Bublík | Komentářů: 12
14.6. 14:00 | Bezpečnostní upozornění

Intel potvrdil (INTEL-SA-00145) další bezpečnostní chybu ve svých procesorech. Jedná se o chybu CVE-2018-3665 s názvem LazyFP.

Ladislav Hagara | Komentářů: 12
14.6. 11:00 | Nová verze

Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 153. brněnský sraz, který proběhne v pátek 15. června od 18:00 v restauraci U OSLŮ na ulici Sokolská 361/10. Pro zájemce proběhne krátké promítání z výletu do Černobylu.

Ladislav Hagara | Komentářů: 0
13.6. 19:58 | Upozornění

Server lupa.cz rozebírá připravovanou reformu copyrightu v EU a dopad jejího článku 13, který dává internetovým platformám povinnost řešit autorské právo za vlastníky práv, což by v podstatě vedlo k automatizované cenzuře a konci internetu tak, jak ho známe dnes. Podobně v otevřeném dopise varují Vint Cerf, Tim Berners-Lee a jiní odborníci, Cory Doctorow upozorňuje na důsledky pro Wikipedii, nebo github na sdílení kódu.

marbu | Komentářů: 91
12.6. 16:00 | Nová verze

Bylo oznámeno vydání verze 5.13 prostředí KDE Plasma. Přehled nových vlastností i s náhledy v poznámkách k vydání. Videoukázka na YouTube.

Ladislav Hagara | Komentářů: 92
12.6. 11:11 | Zajímavý software

Byla vydána verze 1.8.0 svobodného softwaru Dilay pro 3D modelování technikou digitálního sochání (digital sculpting). Zdrojové kódy jsou k dispozici na GitHubu pod licencí GPLv3. K dispozici je balíček (19,6 MB) ve formátu AppImage. Stačí nastavit právo na spouštění a spustit.

Ladislav Hagara | Komentářů: 10
11.6. 16:55 | Zajímavý projekt

MojeFedora.cz představuje repozitář Flatpaku winepak, který si dává za cíl přinášet do Linuxu aplikace pro Windows v podobě Flatpaku. K běhu aplikací se používá překladová vrstva Wine.

Ladislav Hagara | Komentářů: 27
11.6. 16:33 | Komunita

V rámci letních slev na GOG.com lze do středy 13. června do 15:00 získat počítačovou hru Ziggurat (Wikipedie) běžící také na Linuxu zdarma a bez DRM.

Ladislav Hagara | Komentářů: 0
Jak čtete delší texty z webových stránek?
 (78%)
 (23%)
 (4%)
 (7%)
 (3%)
 (11%)
Celkem 194 hlasů
 Komentářů: 33, poslední včera 23:59
    Rozcestník

    Dotaz: trigger

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

    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.