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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
dnes 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

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

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 16
včera 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 26
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 780 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama
Š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: 248×
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: 42 | 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: 66 | 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: 66 | 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.