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 13:33 | IT novinky

    Byl představen ICT Supply Chain Security Toolbox, společný nezávazný rámec EU pro posuzování a snižování kybernetických bezpečnostních rizik v ICT dodavatelských řetězcích. Toolbox identifikuje možné rizikové scénáře ovlivňující ICT dodavatelské řetězce a na jejich podkladě nabízí koordinovaná doporučení k hodnocení a mitigaci rizik. Doporučení se dotýkají mj. podpory multi-vendor strategií a snižování závislostí na vysoce

    … více »
    Ladislav Hagara | Komentářů: 3
    dnes 12:22 | Humor

    Nizozemský ministr obrany Gijs Tuinman prohlásil, že je možné stíhací letouny F-35 'jailbreaknout stejně jako iPhony', tedy upravit jejich software bez souhlasu USA nebo spolupráce s výrobcem Lockheed Martin. Tento výrok zazněl v rozhovoru na BNR Nieuwsradio, kde Tuinman naznačil, že evropské země by mohly potřebovat větší nezávislost na americké technologii. Jak by bylo jailbreak možné technicky provést pan ministr nijak nespecifikoval, nicméně je známé, že izraelské letectvo ve svých modifikovaných stíhačkách F-35 používá vlastní software.

    NUKE GAZA! 🎆 | Komentářů: 1
    dnes 06:00 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 162 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 05:55 | IT novinky

    Sdružení CZ.NIC, správce české národní domény, zveřejnilo Domain Report za rok 2025 s klíčovými daty o vývoji domény .CZ. Na konci roku 2025 bylo v registru české národní domény celkem 1 515 860 s koncovkou .CZ. Průměrně bylo měsíčně zaregistrováno 16 222 domén, přičemž nejvíce registrací proběhlo v lednu (18 722) a nejméně pak v červnu (14 559). Podíl domén zabezpečených pomocí technologie DNSSEC se po několika letech stagnace výrazně

    … více »
    Ladislav Hagara | Komentářů: 8
    včera 18:33 | IT novinky

    Google představil telefon Pixel 10a. S funkci Satelitní SOS, která vás spojí se záchrannými složkami i v místech bez signálu Wi-Fi nebo mobilní sítě. Cena telefonu je od 13 290 Kč.

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

    Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Fedora 43 Asahi Remix s KDE Plasma už funguje na M3. Zatím ale bez GPU akcelerace. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.

    Ladislav Hagara | Komentářů: 0
    včera 14:00 | IT novinky

    Red Hat představil nový nástroj Digital Sovereignty Readiness Assessment (GitHub), který organizacím umožní vyhodnotit jejich aktuální schopnosti v oblasti digitální suverenity a nastavit strategii pro nezávislé a bezpečné řízení IT prostředí.

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

    BarraCUDA je neoficiální open-source CUDA kompilátor, ale pro grafické karty AMD (CUDA je proprietární technologie společnosti NVIDIA). BarraCUDA dokáže přeložit zdrojové *.cu soubory (prakticky C/C++) přímo do strojového kódu mikroarchitektury GFX11 a vytvořit tak ELF *.hsaco binární soubory, spustitelné na grafické kartě AMD. Zdrojový kód (převážně C99) je k dispozici na GitHubu, pod licencí Apache-2.0.

    NUKE GAZA! 🎆 | Komentářů: 1
    17.2. 17:00 | IT novinky

    Podvodné reklamy na sociálních internetových platformách, jako je Facebook, Instagram nebo X, vytvořily loni v Česku jejich provozovatelům příjmy 139 milionů eur, tedy zhruba 3,4 miliardy korun. Proti roku 2022 je to nárůst o 51 procent. Vyplývá to z analýzy Juniper Research pro společnost Revolut. Podle výzkumu je v Česku zhruba jedna ze sedmi zobrazených reklam podvodná. Je to o 14,5 procenta více, než je evropský průměr, kde je podvodná každá desátá reklama.

    Ladislav Hagara | Komentářů: 10
    17.2. 15:44 | Nová verze

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.6 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (11%)
     (27%)
     (3%)
     (4%)
     (2%)
     (12%)
     (27%)
    Celkem 905 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    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: 361×
    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.