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 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 1
    dnes 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

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

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 0
    včera 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 23
    včera 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    včera 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

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

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

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

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 11
    13.5. 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1632 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Postgres sequence

    25.8.2015 00:18 Marek
    Postgres sequence
    Přečteno: 1095×
    Dobrý den,

    Nevíte, prosím, někdo, zda je u postgres zaručeno, že ID získané autoinkrementací je vždy u posledního zápisu nejvyšší (když pominu přetečení)?

    Jde mi o případ transakcí/nezávaslých připojení, kdy jedna transakce "A" vkládájící záznam začne dřív, ale zároveň i skončí později, než druhá:

    1) v transakci A je přidán záznam 2) v transakci B je přidán záznam 3) transakce B je commitnuta 4) transakce A je commitnuta

    Je ID záznamu A zaručeně vyšší než ID záznamu B?

    Děkuji

    Řešení dotazu:


    Odpovědi

    okbob avatar 25.8.2015 06:01 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres sequence
    Sekvence nemají žádnou závislost na transakce - číslo se generuje v okamžiku, kdy si o něj řeknete - tj typicky, kdy provádíte INSERT. Pak jestli a kdy provedete COMMIT je vůči získané hodnotě a stavu sekvence absolutně jedno.
    Řešení 1× (okbob)
    25.8.2015 15:20 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: Postgres sequence
    Suhlas. Ak by som mal toto prelozit do odpovede na povodnu otazku:

    ID zaznamu A je nizsie nez ID zaznamu B. - pretoze transakcia A vygenerovala sequencerom cislo skor nez transakcia B

    Jediny sposob (ktory ma napada), akym zhruba monitorovat cas/poradie commitov je pouzit DEFERRED (CONSTRAINT) TRIGGER.
    okbob avatar 25.8.2015 16:52 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres sequence
    CONSTRAINT TRIGGER může být pouze typu AFTER - tj nelze v něm již měnit data.
    25.8.2015 19:33 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: Postgres sequence
    Sice to nejde cez record NEW, ale ide to SQL statementom:
    
    CREATE SEQUENCE commit_seq;
    
    CREATE TABLE t
    (
       id          serial    NOT NULL PRIMARY KEY
     , tsInsert    timestamp NOT NULL DEFAULT clock_timestamp()
     , seqCommit   int
     , tsCommit    timestamp
    );
    
    CREATE OR REPLACE FUNCTION ai_d_commit()
    RETURNS trigger AS
    $$
       BEGIN
          UPDATE t
             SET seqCommit = nextval('commit_seq'::regclass)
               , tsCommit  = clock_timestamp()
             WHERE id = NEW.id
          ;
          RETURN NEW;
       END;
    $$
    LANGUAGE plpgsql
    VOLATILE;
    
    CREATE CONSTRAINT TRIGGER ai_d_commit
       AFTER INSERT
       ON t
       DEFERRABLE INITIALLY DEFERRED
       FOR EACH ROW
       EXECUTE PROCEDURE ai_d_commit()
    ;
    
    BEGIN;
    INSERT INTO t DEFAULT VALUES;
    SELECT pg_sleep(2);
    COMMIT;
    SELECT * FROM t;
    
    CLI test:
    psql -Upostgres -c"BEGIN; INSERT INTO t DEFAULT VALUES; SELECT pg_sleep(2); COMMIT; SELECT * FROM t ORDER BY id;" &\
    sleep 1;\
    psql -Upostgres -c"BEGIN; INSERT INTO t DEFAULT VALUES; COMMIT; SELECT * FROM t ORDER BY id;"
    Este skusam vymysliet naco by to komu bolo. Navyse to poradie bude iba priblizne - kedze to pochopitelne bezi pred commitom, tak moment skutocneho commitu moze byt v inom poradi, nez aky ukazuje sequencer. Ak by to bolo naozaj dolezite, rozmyslal by som skor nad serializaciou.
    okbob avatar 26.8.2015 13:29 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres sequence
    Trochu bych se bal v triggeru delat DML nad stejnou tabulkou - pro kombinaci INSERT/UPDATE to zafunguje (problem je vetsi narocnost - generuji se nove verze), pro kombinaci UPDATE/UPDATE nedokazi odhadnout, jestli tam nebude side effect pripadne rekurze na triggerech. Rozhodne bych do takoveho navrhu za zadnych okolnosti nesel.
    26.8.2015 14:56 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: Postgres sequence
    Je asi jedno, ci clovek robi DML nad rovnakou, alebo inou tabulkou: v oboch pripadoch vznika novy tuple a nepriama rekurzia hrozi tiez. Napriklad v SQLite triggeroch ani ina moznost nie je - len pouzitie DML. Urcite by som bol opatrny, ale zbytocne by som sa neobmedzoval. Nakoniec, nasledujuca veta je v dokumentacii viac nez desat rokov:
    It is the trigger programmer's responsibility to avoid infinite recursion
    Zo skusenosti, pre zamedzenie rekurzie triggerov je rozumne pouzit klauzulu WHEN.
    26.8.2015 11:39 Marek
    Rozbalit Rozbalit vše Re: Postgres sequence
    Dik moc obema.
    25.8.2015 08:34 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Postgres sequence
    Je chybou, ak sa aplikačná logika spolieha na usporiadanie hodnôt generovaných sekvenciou, resp. na usporiadanie hodnôt syntetického primárneho kľúča vo všeobecnosti. Ak aplikačná logika potrebuje usporiadanie, mala by mať na tento účel určený stĺpec a generovanie jeho hodôt má byť starostlivo navrhnuté a implementované s ohľadom na potreby aplikácie; ak sa bude jednať o usporiadanie úplné, nie čiastočné, môže sa teoreticky tento stĺpec stať aj primárnym kľúčom, prakticky to ale tiež nie najlepší nápad.

    Inak povedané, nechajte zodpovednosť jednoznačnej identifikácie záznamu na primárnom kľúči, ale zodpovednosť za usporiadanie záznamov v tabuľke urobte zodpovedným iný, špeciálne na tento účel navrhnutý stĺpec. Naplníte tak princíp jednej zodpovednosti a oceníte to okamžite, ako nastane potreba usporiadať záznamy podľa iného, v tejto chvíli ešte neznámeho kritéria.

    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.