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 14:55 | Bezpečnostní upozornění

    Discord potvrdil únik osobních údajů přibližně 70 000 uživatelů. Incident se týká uživatelů po celém světě, především těch, kteří v rámci ověřování svého věku nahráli do aplikace doklad totožnosti. Únik informací se netýkal systémů samotné platformy, ale došlo k němu přes kompromitovaný účet pracovníka zákaznické podpory u externího poskytovatele služeb.

    Ladislav Hagara | Komentářů: 0
    dnes 14:44 | IT novinky

    Americká společnost OpenAI, která provozuje chatbota ChatGPT, kvůli výrobě vlastních procesorů pro umělou inteligenci (AI) spojí síly s firmou Broadcom. Firmy o tom informovaly (en) ve svém včerejším sdělení. OpenAI se snaží zajistit si výpočetní výkon potřebný k uspokojení rostoucí poptávky po svých službách. Akcie Broadcomu po zprávě výrazně zpevnily.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Pozvánky

    O víkendu 18. a 19. října lze na brněnském výstavišti navštívit s jednou vstupenkou dvě akce: Maker Faire Brno, "festival tvořivosti, vynálezů a bastlířské radosti", a GameDev Connect, "akci určenou pro všechny současné a hlavně budoucí herní vývojáře, kteří touží proniknout do jednoho z nejúžasnějších průmyslů na světě".

    Ladislav Hagara | Komentářů: 0
    včera 23:55 | IT novinky

    Do 20. října do 19:00 běží na Steamu přehlídka nadcházejících her Festival Steam Next | říjen 2025 (YouTube) doplněná demoverzemi, přenosy a dalšími aktivitami. Demoverze lze hrát zdarma.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | IT novinky

    O zavedení nástroje na monitorování online konverzací v rámci boje proti dětské pornografii (tzv. Chat Control) měli ministři vnitra rozhodovat na úterním společném zasedání v Lucemburku. Plán dánského předsednictví Rady EU ale před pár dny ztroskotal, když se ukázalo, že Chat Control nemá dostatečnou podporu.

    Ladislav Hagara | Komentářů: 6
    včera 13:11 | Pozvánky

    Již toto úterý proběhne každoměsíční akce Virtuální Bastlírna, kterou pořádá projekt MacGyver. Jde o virtuální posezení u piva a volné klábosení o různých zajímavostech ze světa elektroniky, softwaru i techniky. V posledním měsíci se stalo nemálo zajímavostí týkajících se spousty bastlířů - kupříkladu Arduino nyní patří pod Qualcomm, Raspberry Pi vydalo nový počítač, ale potichu i miniaturní compute module. Pro AMS od Bambu Lab se

    … více »
    bkralik | Komentářů: 0
    včera 11:22 | IT novinky

    Google zpřístupňuje své AI nástroje českým univerzitním studentům prostřednictvím předplatného Google AI Pro na 12 měsíců bez poplatku. Platnost nabídky vyprší 9. prosince 2025.

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

    MicroPythonOS je operační systém napsaný v MicroPythonu určený především pro mikrokontroléry jako ESP32. Zdrojové kódy jsou k dispozici na GitHubu.

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

    Byl vydán LineageOS 23 (Mastodon). LineageOS (Wikipedie) je svobodný operační systém pro chytré telefony, tablety a set-top boxy založený na Androidu. Jedná se o nástupce CyanogenModu. LineageOS 23 je založený na Androidu 16.

    Ladislav Hagara | Komentářů: 0
    11.10. 15:33 | Komunita

    Na YouTube byly zveřejněny videozáznamy přednášek z hackerské konference DEF CON 33, jež proběhla 7. až 10. srpna v Las Vegas.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (37%)
     (46%)
     (17%)
     (18%)
     (22%)
     (16%)
     (18%)
     (16%)
     (16%)
    Celkem 218 hlasů
     Komentářů: 14, poslední dnes 09:04
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Postgres a 0 namiesto DEFAULT pre serial pri inserte

    hikikomori82 avatar 10.12.2009 16:12 hikikomori82 | skóre: 18 | blog: foobar | Košice
    Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Přečteno: 323×
    Snazim sa portovat jeden program z Informixu na Postgres. V tabulkach so serialom v informixe sa pouziva pri inserte 0, v postgrese je to slovo DEFAULT. Neviete poradit ako by som mohol upravit tabulku v postgrese aby ked spravim:

    insert into user values (0, 'Janko');

    aby to vykonalo:

    insert into user values (DEFAULT, 'Janko');

    Řešení dotazu:


    Odpovědi

    10.12.2009 16:44 ZAH | skóre: 43 | blog: ZAH
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Nevím jestli dobře rozumím máte asi aplikaci které toto pošle, kterou nemůžete změnit ? Zkusil bych to vyřešit přes trigger before insert. jesliže hodnota je 0 potom dosaď hodnotu null a zafunguje default v tabulce.
    Řešení 1× (hikikomori82 (tazatel))
    okbob avatar 11.12.2009 08:17 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Hmm...

    tak toho bych dosahl asi jedine v before triggeru. Zhruba napsat

    IF NEW.id = 0 THEN NEW.id = nextval('nazev sekvence'); END IF; RETURN NEW;

    jinak je to takovy portacni hack - takze, minimalne chce to hodne okomentovat a jeste lepe sahnout do aplikace a 0 v SQL prikazech nahradit klicovym slovem DEFAULT.

    Pavel
    hikikomori82 avatar 11.12.2009 09:49 hikikomori82 | skóre: 18 | blog: foobar | Košice
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Vdaka, podarilo sa mi to rozchodit.

    Vytvorenie databazy

    create database foo;
    
    create user john;
    
    grant all on database foo to john;
    
    \connect foo;
    

    Vytvorenie tabulky

    create table pokus (i_pokus serial, v_pokus varchar(80));
    
    create unique index p_pokus_1 on pokus(i_pokus);
    
    create language plpgsql;
    
    create or replace function u_pokus_before_insert() returns trigger as '
    begin
    if new.i_pokus = 0 then
    new.i_pokus = nextval(''pokus_i_pokus_seq'');
    end if;
    return new;
    end
    ' language 'plpgsql';
    
    create trigger t_pokus_1 before insert on pokus for each row execute procedure u_pokus_before_insert();
    

    Vytvorenie tabulky

    insert into pokus values (0, 'alfa');
    
    insert into pokus values (0, 'beta');
    
    insert into pokus values (0, 'gama');
    
    select * from pokus;
    
     i_pokus | v_pokus 
    ---------+---------
           1 | alfa
           2 | beta
           3 | gama
    
    hikikomori82 avatar 11.12.2009 09:56 hikikomori82 | skóre: 18 | blog: foobar | Košice
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Dalo by sa nejak tu funkciu zuniverzalnit tak aby ju mohlo pouzivat viac trigerrov pre viac tabuliek? Viem vnutri tej funkcie zistit meno tabulky (alebo sekvencie) s ktorou teraz pracujem?
    okbob avatar 11.12.2009 10:07 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    teoreticky ano - nicmene nesmel bys pouzit plpgsql. Uvnitr jmeno tabulky zjistis - a teoreticky dohledas docela snadno i odpovidajici sekvence. Nicmene - z jenoducheho citelneho triggeru se stane komplikovanejsi trigger - obsahujici dalsi (relativne drahe) dotazy. To by melo smysl, jen pokud by se trigger psal v C, a pomerne sofistikovane by se nektere hodnoty ukladaly do cache. To si myslim, ze je proveditelne a ve vysledku funkcni a efektivni. V pripade plpgsql nebo "vyssich" PL jazyku nedoporucuji.

    Pavel
    hikikomori82 avatar 11.12.2009 10:58 hikikomori82 | skóre: 18 | blog: foobar | Košice
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    > Uvnitr jmeno tabulky zjistis

    Vsetky sekvencie sa volaju "tabulka_i_tabulka_seq", nemozem tam dat jednoducho MenoTabulky+"_i_"+MenoTabulky+"_seq" ?
    okbob avatar 11.12.2009 12:37 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Ta konvence plati jenom pro typ serial - pokud si jste jisty, ze pouzivate pouze takto vytvorene sekvence, tak v nekterem PL (jinem nez plpgsql) takovy trigger si napsat muzete. Nazev tabulky nad kterou je trigger volan, je z tela triggeru dostupny - viz dokumentace.
    hikikomori82 avatar 11.12.2009 12:43 hikikomori82 | skóre: 18 | blog: foobar | Košice
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Evidentne vies ako sa to vola ale nechces mi to povedat. Ja to budem teraz dva tyzdne v tej dokumentacii hladat. Tak sa zatial vsetci majte. Potom sa ozvem.
    11.12.2009 13:18 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    nie vždy ... po rename table ostáva default rovnaká. Najlepšie riešenie je zistiť si default hodnotu (napr: pg_attrdef) a použiť tú :-)

    takisto existujú ľudia, čo vygenerovanú hodnotu sekvencie transformujú (napr v jednej Celko-vej knihe je popísaný celkom jednoduchý spôsob), aby "indexy boli lepšími indexami" :-)
    Řešení 1× (hikikomori82 (tazatel))
    11.12.2009 16:33 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Místo triggeru použijte raději pravidlo (rule). Triggery a pravidla jsou hodně podobné, často zaměnitelné, ale v tomto případě je to ideální případ pro pravidla - pravidla slouží právě pro přepsání (změnu) SQL příkazu.
    11.12.2009 17:24 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    +1 :-)
    11.12.2009 17:29 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Od té doby, co je tady funkce "Označit jako řešení", nemusíte psát v poradně komentáře "+1" :-)
    12.12.2009 06:09 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    komentár mal znamenať "a sakra, som už dostatočne blbý na to, aby som si na to nespomenul" :-)
    11.12.2009 08:35 FooBar
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    Jak rikaji ostatni, trigger. Ale jak rikaji ostatni, zmen to v aplikaci, jinak najednou zjistis, ze se ti INSERTy vykonavaji podezrele pomalu:)
    okbob avatar 11.12.2009 10:00 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Postgres a 0 namiesto DEFAULT pre serial pri inserte
    V tomto pripade je rezie minimalni - trigger skoro nic neobsahuje - resp. obsahuje pouze volani inkrementu sekvence, to by melo byt v pohode (DEFAULT ma take urcitou rezii). Jako rizikove spis vidim zmenu chovani. Co kdyby, cirou nahodou, tam nekdo nekdy v budoucnu chtel narvat 0. Tak na to bude koukat jak vyvorana mys. Zase na druhou stranu,v triggeru se neaktivuje "silene" zavislosti, takze bych se toho vubec nebal.

    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.