PostgreSQL - tipy

Restore databázy z dump súboru

sudo -u postgres pg_restore --create --clean -d postgres /path/to/file/dochadzka_XXXXXXXXYYYY.dump

Backup databázy do dump súboru

pg_dump -Fc -U postgres -W dochadzka > dochadzka_XXXXXXXXYYYY.dump

Skopírovanie celej databázy vrámci jedného servera

CREATE DATABASE dochadzka_test WITH TEMPLATE dochadzka OWNER postgres_demo;

SQLSTATE[XXXX]: Unique violation: 7 ERROR: duplicate key value violates unique constraint "YYYY"

  • Spôsobuje to odlišné správanie auto incrementu v PgSQL - využívajú sa tu sekvencie (pre každý auto increment stĺpec zvlášť), ktoré definujú nasledujúcu hodnotu. V prípade manipulácie cez SQL príkazy (hromadný INSERT) sa stane, že sa sekvencia nezmení. Takže v DB môžeme mať MAX(id) == 5000, ale nextid sekvencie je napr 5.
  • Nasledujúce ID konkrétnej sekvenvecie (jej názov spolu s príkazom možno nájsť v definícii tabuľky v stĺpci Default (value)), a vypísať si ho môžeme jednoduchým selectom:
SELECT nextval('work_days_id_seq')
  • Automatické nastavenie správnej hodnoty sekvencie možno príkazom:
SELECT setval(pg_get_serial_sequence('NAZOV_TABULKY', 'id'), coalesce(max(id)+1,1), false) FROM "NAZOV_TABULKY";

Anonymizačný script pre dochádzku

UPDATE employees SET 
first_name = (ARRAY['Drahoslav', 'Severín', 'Alexej', 'Rastislav', 'Radovan', 'Dalibor', 'Vincent', 'Miloš', 'Timotej', 'Emil', 'Erik', 'Jaromír', 'Roman', 'Matej','Viktor', 'Alexander', 'Radomír', 'Albín', 'Bohumil', 'Kazimír', 'Fridrich', 'Radoslav', 'Tomáš', 'Alan', 'Branislav', 'Bruno', 'Gregor', 'Jozef', 'Adrián', 'Marián', 'Miroslav', 'Richard', 'Igor', 'Július', 'Rudolf', 'Marcel', 'Vojtech', 'Juraj', 'Marek', 'Jaroslav', 'Júlia', 'Dušan', 'Viliam', 'Norbert', 'Róbert', 'Anton', 'Ján', 'Peter', 'Pavol', 'Patrik', 'Oliver', 'Ivan', 'Kamil', 'Daniel', 'Vladimír', 'Jakub', 'Dominik', 'Ľubomír', 'Filip', 'Ľudovít', 'Samuel', 'Matúš', 'Ľuboš', 'Michal', 'František', 'Boris', 'Lukáš', 'Kristián', 'Denis', 'Karol', 'Tibor', 'Maroš', 'Martin', 'Stanislav', 'Milan', 'Ondrej', 'Andrej', 'Adam', 'Štefan', 'Dávid'])[floor(random()*80)+1], 
last_name = (ARRAY['Sloboda', 'Novotný', 'Kučera', 'Veselý', 'Král', 'Kolár', 'Bartoš','Polák', 'Kopecký', 'Konečný', 'Adamec', 'Almáši', 'Anderle', 'Antal', 'Bajnok', 'Balaša', 'Balog', 'Balogh', 'Baláž', 'Baran', 'Baranka', 'Bartovič', 'Bartoš', 'Bača', 'Bella', 'Beran','Bernolák', 'Beňo', 'Bicek', 'Bielik', 'Blaho', 'Bondra', 'Bosák', 'Boška', 'Brezina', 'Bugár', 'Chalupka', 'Chudík','Danko', 'Debnár', 'Doležal', 'Dočolomanský', 'Dubovský','Dudek', 'Dula', 'Dulla', 'Dusík', 'Dzurjanin', 'Fabian', 'Fabián', 'Fajnor', 'Farkašovský', 'Feldek', 'Filc','Ftorek', 'Galis', 'Gallo', 'Gašpar', 'Gašparovič', 'Gocník', 'Golonka', 'Greguš', 'Grznár', 'Hablák', 'Habšuda','Halák', 'Hanko', 'Hanzal', 'Hanzel', 'Hanzel', 'Haščák', 'Heretik', 'Hečko', 'Hečková', 'Hlaváček', 'Hlinka','Horváth', 'Hossa', 'Hraško', 'Hric', 'Hrmo', 'Hrušovský', 'Huba', 'Hudáček', 'Hála', 'Ihnačák', 'Janoška', 'Jantošovič','Jurina', 'Jurinová', 'Jurík', 'Jáni', 'Jánošík', 'Kaliský', 'Karul', 'Karvaš', 'Keníž', 'Klapka', 'Klaus', 'Kolník','Korec', 'Kostrec', 'Kováč', 'Kováčik', 'Koza', 'Kubík', 'Kučera', 'Labuda', 'Langoš', 'Lexa', 'Lintner','Lukáč', 'Lupták', 'Líška', 'Majeský', 'Malachovský', 'Malíšek', 'Marián', 'Masaryk', 'Matiaško', 'Medveď', 'Menyhért','Mečiar', 'Mečíř', 'Mikloško', 'Mikulík', 'Mikuš', 'Mikúš', 'Mišík', 'Mojžiš', 'Mokroš', 'Molnár', 'Moravčík', 'Musil', 'Nagy','Nemec', 'Novák', 'Pavlikovský', 'Pašek', 'Paška','Petrovický', 'Petruška', 'Podhradská', 'Podkonický', 'Poliak', 'Procházka', 'Raši','Repiský', 'Romančík', 'Rúfus', 'Sedliak', 'Sidor','Skutecký', 'Sloboda', 'Slovák', 'Smrek', 'Straka', 'Szabó', 'Sámel', 'Sýkora', 'Tatar','Tomeček', 'Truben', 'Turčok', 'Tóth', 'Urblík', 'Valent', 'Valuška','Varga', 'Vašíček', 'Vesel', 'Vico', 'Višňovský', 'Zima', 'Zátopek', 'Zúbrik', 'Čaplovič','Čarnogurský', 'Čierny', 'Ďaďo', 'Ďurica', 'Ďuriš', 'Šimonovič', 'Štefanka', 'Šulc', 'Šurka'])[floor(random()*186)+1],
maiden_name = last_name,
phone = null,
email = CONCAT('emp',id,'@dochadzka.app');

UPDATE employee_personal_data SET 
birth_date = date(birth_date + trunc(random()  * 500) * '1 day'::interval),
birth_number = null,
birth_place = (ARRAY['Albínov','Andice','Baďan','Bakta','Balvany','Baňa','Banka','Banky','Bánov','Banský Studenec','Bardejov','Bardejovská Nová Ves','Bardejovská Zábava','Bartošova Lehôtka','Baškovce','Bašovce','Bečov','Behynce','Belejovce','Belín','Belina','Beluj','Benice','Beňov','Beňova Lehota','Beňušovce','Betlenovce','Bezdedov - Vieska','Biskupice','Biskupice','Biskupice','Blesovce','Bodice','Bodov','Boheľov','Bojná','Bojnice','Bojnice - kúpele','Bokša','Boľkovce','Borov','Brehy','Brekov','Brestov','Brestov nad Laborcom','Brestovec','Breznica','Breznička','Brezolupy','Brezov','Brezovica','Brusník','Bučuháza','Budulov','Bujakovo','Bukovina','Bukovina','Bulhary','Bystrá','Bytča','Bzenica','Bziny','Celulózka','Cemjata','Cigeľ','Čačín','Čáčov','Čadečka','Čamovce','Čankov','Čaradice','Čenkesfa','Čerenčany','Čergov','Čerín','Čermáň','Černochov Vrch','Červená Voda','Červeňany','Čičava','Čierne Pole','Čilistov','Čremošné','Čučma','Debraď','Dekýš','Demänová','Demänovská Dolina','Didka','Diviaky','Dlhá','Dlhá Lúka','Dlhé Stráže','Dobrá','Dobroslava','Dolná Mičiná','Dolná Môlča','Dolná Štubňa','Dolná Ves','Dolná Ždaňa','Dolné Kočkovce','Dolné Naštice','Dolné Ozorovce','Dolný Kubín','Dolný Moštenec','Dovalovo','Drahošanka','Dražovce','Drienica','Drienovec','Drienovská Nová Ves','Dubie','Dubnica','Ďulov Dvor','Dunajská Streda','Duplín','Ďurčiná','Dúžava','Dyčka','Egreš','Fejséš','Fijaš','Fiľakovo','Fiľakovské Kľačany','Fiľakovské Kováče','Filice','Forbasy','Francovce','Galanta','Gáň','Gánovce','Gelnica','Gemer','Géňa','Giraltovce','Hačava','Hadovce','Háj','Hájiky - Maky','Haniska','Harichovce','Harmónia','Havka','Heďbeneéte','Hetméň','Hlboké nad Váhom','Hliník','Hliník nad Hronom','Hliník nad Váhom','Hlivištia','Hniezdne','Hnúšťa','Holanovo','Horelica','Horňa','Horná Mičiná','Horná Môlča','Horná Trnávka','Horná Ves','Horné Kočkovce','Horný Čepeň','Horný Moštenec','Horný Ohaj','Horný Smokovec','Horša','Hoštiná','Hrabovčík','Hrabové','Hrabovec nad Laborcom','Hrabovka','Hrabovo','Hrboltová','Hrkovce','Hrubý Šúr','Humenné','Hurbanova Ves','Chmeľnica','Chotár','Chrabrany','Chrenová','Chyzerovce','Ihráč','Ihrište','Iľanovo','Ilava','Iliavka','Ilija','Ižop','Jahodníky','Jakovany','Jakub','Jakubovany','Jamník','Jarabá','Jarok','Jasenov','Jasenová','Jastrabá','Javorinka','Jazviny','Jurkova Voľa','Kalinčiakovo','Kalinov','Kalinovo','Kalnište','Kamenec','Kameničná','Kamenný Vrch','Kapišová','Kapušianske Kľačany','Kapušianske Vojkovce','Karolína','Kava','Kendice','Kežmarok','Kľačno','Klastava','Klobušice','Kňažia','Kobylnice','Kocurice','Kochanovce','Kolónia','Komárany','Komárovce','Konkoľ','Kopernica','Koplotovce','Kostiviarska','Kostivrch','Kostolná pri Dunaji','Kostolný Sek','Košice - Kavečany','Košice - Staré Mesto','Košice - Vyšné Opátske','Košolná','Košúty','Kožuchov','Kračúnovce','Krahule','Králik','Kráľová','Kráľovianky','Kráľovský Chlmec','Krásnovce','Krásny Brod','Kremnica','Kremnické Bane','Krišovská Liesková','Krížany','Krížny Vrch','Krížová Ves','Krškany','Krupina','Krušinec','Kružno','Kubrá','Kubrica','Kukučínov','Kunešov','Kunov','Kurimany','Kurinec','Kurtáň','Kútniky','Kúty','Kúty','Kvetnica','Kynceľová','Kynek','Kysihýbel','Lacková','Lackovce','Ladislavov Dvor','Ladomerská Vieska','Lándor','Laškovce','Látkovce','Lehôtka pod Brehmi','Lesné','Leštiny','Levoča','Levočská Dolina','Levočské Lúky','Lidér Tejed','Liesková','Likier','Lipovník','Liptovská Porúbka','Liptovská Štiavnica','Liptovský Hrádok','Liptovský Peter','Liptovský Trnovec','Lúčka','Lúčky','Lužany pri Topli','Lysá nad Dunajcom','Majer','Majere','Malá Bytča','Malá Čausa','Malá Čierna','Malá Iža','Malá Ves','Malacky','Malatiná','Malé Bedzany','Malé Blahovo','Malé Dvorany','Malé Dvorníky','Malé Chlievany','Malé Krškany','Malé Ludince','Malé Orvište','Malé Ozorovce','Malé Straciny','Malinô Brdo','Malý Bysterec','Malý Kiar','Malý Krtíš','Malý Pesek','Malý Ruskov','Malý Slavkov','Malý Šariš','Margecany','Martin','Svätý Martin','Martin nad Žitavou','Martovce','Maštinec','Maťovské Vojkovce','Matúškovo','Meďov','Medzibrodie nad Oravou','Medzihradné','Medzilaborce','Melek','Mičakovce','Miezgovce','Miháľov','Michalovce','Mikšová','Mikula','Mikušovce','Milhostov','Milinovice','Milošová','Milovaná','Mliečany','Mliečno','Mlynárce','Močarany','Modra','Modrý Kameň','Mojín','Mojš','Mojšová Lúčka','Mokrá Lúka','Mokraď','Mokrance','Mokroluh','Moldava nad Bodvou','Môlča','Môťová','Muráň','Muránska Dlhá Lúka','Muránska Huta','Muránska Lehota','Muránska Zdychava','Myslina','Nadabula','Ňagov','Námestovo','Nebojsa','Nemce','Nemčice','Neresnica','Nevoľné','Nitra - Staré Mesto','Nitrianske Hrnčiarovce','Nitriansky Hrádok','Nixbrod','Nižná Jedľová','Nižná Pisaná','Nižná Pokoradz','Nižná Rybnica','Nižný Kručov','Nosice','Nová Baňa','Nová Osada','Nová Polianka','Nové Mesto nad Váhom','Nový Majer','Nový Ruskov','Nový Smokovec','Nový Svet','Olšina','Ondavské Matiašovce','Opatová','Opatová','Orkucany','Orlové','Osádka','Ostrov','Oščadnica','Padáň','Palota','Palúdzka','Paprad','Párnica','Párovské Háje','Pataš','Pavčina Lehota','Pavlovce','Petrovce nad Laborcom','Petrovec','Piesok','Piešťany','Pichne','Pinciná','Plechotice','Ploštín','Počúvadlianske Jazero','Počúvadlo','Pódafa','Podháj','Podhradie','Podlavice','Podmanín','Podsadek','Podtureň','Podzávoz','Pokryváč','Polianka','Polkanová (č.d.1','2','3)','Polom','Poltár','Poprad','Potoky','Potôčky','Povoda','Pozdišovce','Praznov','Práznovce','Predná Hora','Predné Halny','Preseľany nad Ipľom','Prestavlky','Príboj','Prievidza','Prievidza - Kopanice','Prievidza - Necpaly','Prievidza - Píly','Prievidza - Staré Mesto','Prievidza - Štvrte','Prievrana','Prosné','Prostredná Môlča','Pšurnovice','Pucov','Púchov','Radvaň nad Laborcom','Rajec','Rakovčík','Rakša','Ratka','Reca (č. 380','381','383','384))','Revúca','Revúčka','Riečka',' ostatné ulice','Rieka','Richvald','Rimavská Sobota','Rimavské Janovce','Rokytov','Rokytovce','Rovensko','Rozina','Rožňava','Rožňavská Baňa','Rudná','Ružová dolina','Rybárpole','Rychňava','Sabinov','Sabová','Sebedín','Sebedín - Bečov','Sečovce','Senec','Senica','Senica','Senné','Sereď','Sikenica','Sitnianska','Sitník','Skalica','Skubín','Slaná Lehota','Slanická Osada','Slatinka','Snina','Sobôtka','Sobrance','Sobranecké Kúpele','Sotina','Spišská Belá','Spišská Sobota','Spišská Stará Ves','Spišské Tomášovce','Srňacie','Stará Huta','Stará Kremnička','Stará Ľubovňa','Stará Myjava','Stará Turá','Starňa','Starý Smokovec','Stráže pod Tatrami','Strážky','Strážov','Streženice','Stročín','Stropkov','Suchá nad Parnou','Suché','Súš','Sútor','Sverepec','Svidník','Svodov','Šahy','Šalgovík','Šalková','Šamaja','Šamorín','Šamudovce','Šandal','Šášovské Podhradie','Šíd','Šopora','Špania Dolina','Štále','Štefanovce','Štefultov','Štiavnička','Štitáre','Šuja','Šuľa','Šurany','Šutovce','Tajná','Tarnov','Tatranská Polianka','Tatranské Zruby','Teplička','Teplička nad Váhom','Tešmák','Tibava','Tisinec','Töböréte','Tomčany','Topoľany','Topolecká','Tornaľa','Tovarné','Tovarnianska Polianka','Tovarníky','Trebišov','Trenčianska Teplá','Trhyňa','Trnávka','Trnové','Trstená','Turčianske Teplice','Turčiansky Michal','Tureň','U Hluška','U Siheľnika','Udiča','Uľanka','Upohlav','Ústie nad Priehradou','Valaškovce','Valentovce','Vavrečka','Včelinec','Vék','Veľká','Veľká Bytča','Veľká Čausa','Veľká Čierna','Veľká Ves','Veľké Bedzany','Veľké Blahovo','Veľké Dvorany','Veľké Dvorníky','Veľké Kapušany','Veľké Krškany','Veľké Orvište','Veľké Ozorovce','Veľké Straciny','Veľkrop','Veľký Bysterec','Veľký Dvor','Veľký Harčáš','Veľký Krtíš','Veľký Meder','Veľký Pesek','Veľký Ruskov','Velušovce','Vieska','Vieska - Bezdedov','Vinice','Vinohrádok','Vinosady','Vojtovce','Vojty','Volica','Vráble','Vranov','Vrbová nad Váhom','Vŕbovec','Vybúchanec','Vydraň','Vydumanec','Vysielač','Vysoká','Vysoké Tatry','Vyšná Jedľová','Vyšná Pisaná','Vyšná Pokoradz','Vyšný Kubín','Zábiedovo','Zadné Halny','Záhorie','Záhrada','Záhrb','Zacharovce','Zalaba','Záskalie','Záturčie','Závada','Závada','Závadka','Zbehňov','Zbudská Belá','Zelené','Zelený Háj','Zemplínske Hradište','Zlatá Osada','Zlaté','Zobor','Zvolenská Slatina','Zvončín','Žabany','Železník','Želiezovce','Žiar','Žiar nad Hronom','Žibritov','Žilinská Lehota','Žitavce','Župčany'])[floor(random()*671)+1],
identity_card_number = null,
iban = null;