Často kladené dotazy (FAQ) PostgreSQL
                                       
   Poslední aktualizace: Středa 23. června 21:10:00 EST 2004
   
   Současný správce: Bruce Momjian (pgman@candle.pha.pa.us)
   
   Přeložil: Pavel Stěhule (stehule@kix.fsv.cvut.cz)
   
   Aktuální verzi tohoto dokumentu naleznete na adrese:
   http://www.PostgreSQL.org/docs/faqs/FAQ.html. Český překlad na adrese:
   http://www.PostgreSQL.org/docs/faqs/FAQ_czech.html.
   
   Odpovědi na dotazy relevantní ke konkrétním platformám lze nalézt na
   adrese: http://www.PostgreSQL.org/docs/index.html.
     _________________________________________________________________
   
                               Obecné otázky
                                      
   1.1) Co je PostgreSQL? Jak se vyslovuje?
   1.2) Jaká je licence na PostgreSQL?
   1.3) Na kterých Unixex lze spustit PostgreSQL?
   1.4) Které ne-unixové platformy jsou podporované?
   1.5) Kde mohu získat PostgreSQL?
   1.6) Kde mohu získat podporu?
   1.7) Kde je poslední verze?
   1.8) Jaká je dostupná dokumentace?
   1.9) Kde najdu seznam známých chyb nebo nepodporovaných vlastností?
   1.10) Jak se mohu naučit SQL?
   1.11) Nemá PostgreSQL problémy s rokem 2000?
   1.12) Jak se připojit k vývojářskému týmu?
   1.13) Kam podat report o chybě?
   1.14) Jak je na tom PostgreSQL v porovnání s jinými databázemi?
   1.15) Jak lze finančně pomoci PostgreSQL?
   
                             User client dotazy
                                      
   2.1) Kde naleznu ODBC ovladače pro PostgreSQL?
   2.2) Jaké nástroje lze použít pro PostgreSQL a web?
   2.3) Existuje grafické rozhraní pro PostgreSQL?
   2.4) Které programovací jazyky mají podporu pro PostgreSQL?
   
                           Administrativní dotazy
                                      
   3.1) Jak nainstalovat PostgreSQL jinam než do /usr/local/pgsql?
   3.2) Při startu postmaster, dostanu chybové hlášení Bad System Call
   nebo core dump. Proč?
   3.3) Při startu postmastera dostanu hlášení o chybě IpcMemoryCreate.
   Proč?
   3.4) Při startu postmastera dostanu hlášení o chybě
   IpcSemaphoreCreate. Proč?
   3.5) Jak povolit nebo zakázat přístup z jiných stanic?
   3.6) Jak ladit databázový stroj na lepší výkon?
   3.7) Jaké jsou možnosti ladění?
   3.8) Proč dostanu "Sorry, too many clients", když se zkouším připojit?
   3.9) K čemu slouží adresář pgsql_tmp?
   3.10) Proč je požadováno dump a obnovení (load) databáze během upgrade
   mezi velkými verzemi PostgreSQL?
   
                              Provozní dotazy
                                      
   4.1) Čím se liší binární a normální kurzor?
   4.2) Jak získat pouze první řádek dotazu? Náhodný řádek?
   4.3) Jak získám seznam tabulek nebo jinak jak jej získá psql?
   4.4) Jak odstraním sloupec tabulky, jak změním jeho typ?
   4.5) Jaká je maximální velikost řádku, tabulky a databáze?
   4.6) Kolik diskového prostoru je potřeba k uložení dat z normálního
   textového souboru?
   4.7) Jak získám seznam vytvořených tabulek, indexů, databází?
   4.8) Můj dotaz je pomalý a nepoužívá vytvořené indexy. Proč?
   4.9) Jak zjistím, jak optimizer dotazu vyhodnocuje můj dotaz?
   4.10) Co to je R-tree index?
   4.11) Co je Genetic Query Optimizer?
   4.12) Jak provést vyhledávání regulárního výrazu case sensitiv,
   insensitiv? Jak použít index pro case insensitive vyhledávání?
   4.13) Jak v dotazu detekovat, že položka je NULL?
   4.14) Jaké jsou rozdíly mezi různými znakovými typy?
   4.15.1) Jak vytvořit serial/auto-increment pole?
   4.15.2) Jak získat hodnotu SERIAL po vložení řádku?
   4.15.3) Nepovede currval() a nextval() k rozhození podmínek při
   souběhu s jinými uživateli?
   4.15.4) Proč není vygenerované číslo použito při přerušení transakce?
   Proč vznikají díry v číslování vlastní sekvencí/SERIAL sloupce?
   4.16) Co to je OID? Co je to TID?
   4.17) Jaký je význam některých výrazů použitých v PostgreSQL?
   4.18) Proč jsem získal chybové hlášení "ERROR: Memory exhausted in
   AllocSetAlloc()"?
   4.19) Jak se dozvím, kterou verzi PostgreSQL používám?
   4.20) Proč operace s velkými objekty končí "invalid large obj
   descriptor"?
   4.21) Jak vytvořit sloupec obsahující implicitně aktuální datum?
   4.22) Proč jsou moje vnořené dotazy používající IN tak pomalé?
   4.23) Jak provést vnější spojení (outer join)?
   4.24) Jak provést dotaz napříč několika databázemi?
   4.25) Může funkce vrátit více řádků nebo sloupců?
   4.26) Proč nelze spolehlivě vytvářet a rušit dočasné tabulky v
   PL/pgSQL funkcích?
   4.27) Jaké jsou možnosti replikace databází?
   4.28) Jaké jsou možnosti šifrování databází?
   
                           Rozšiřování PostgreSQL
                                      
   5.1) Napsal jsem UDF funkci, PostgreSQL však končí dump core?
   5.2) Jak mohu přispět nějakými šikovnými datovými typy a funkcemi do
   PostgreSQL?
   5.3) Jak napsat funkci v C vracející ntici?
   5.4) Modifikoval jsem zdrojové soubory. Tato změna nebyla při
   rekompilaci vzata v potaz. Proč?
     _________________________________________________________________
   
                               Obecné otázky
                                      
    1.1) Co je PostgreSQL? Jak se vyslovuje?
    
   PostgreSQL se vyslovuje Post-Gres-Q-L. Zvukový záznam je dostupný na
   adrese .
   
   PostgreSQL vychází z databáze POSTGRES (a stále je někdy označován
   zjednodušeně jako Postgres) - výzkumného prototypu DBMS nové generace.
   Z postgresu byl převzat silný datový model a bohatý soubor datových
   typů a jeho dotazovací jazyk PostQuel byl nahrazen rozšířenou
   podmnožinou jazyka SQL. PostgreSQL lze používat bez omezení a jeho
   zdrojové kódy jsou volně k dispozici.
   
   PostgreSQL vyvýjí tým vývojářů přihlášených do vývojářské konference
   PostgreSQL. Současným koordinátorem je Marc G. Fournier
   (scrappy@PostgreSQL.org). (viz 1.6 - jak se zapojit). Tento tým je
   zodpovědný za veškerý vývoj PostgreSQL. Jedná se o veřejný projekt,
   který není řízen žádnou firmou. Pokud se chcete zapojit, přečtěte si
   developer's FAQ na adrese
   http://www.PostgreSQL.org/docs/faqs/FAQ_DEV.html
   
   Autory první verze PostgreSQL 1.01 byli Andrew Yu and Jolly Chen. Do
   portace, testování, ladění a rozšiřování kódu se zapojilo mnoho
   dalších vývojářů . Původni kód Postgresu, ze kterého PostgreSQL
   vychází, je výsledkem úsilí mnoha studentů a programátorů pracujících
   pod vedením prof. Michaela Stonebrakera na University of California v
   Berkley.
   
   Původní název software z Berkley byl Postgres. Po přidání jazyka SQL
   se název změnil na Postgres95. Koncem roku 1996 byl RDBMS přejmenován
   na PostgreSQL.
   
    1.2) Jaká je licence na PostgreSQL?
    
   PostgreSQL je předmětem následujících autorských práv:
   
   Dílčí Copyright (c) 1996-2006, PostgreSQL Global Development Group
   Dílčí Copyright (c) 1994-6, Regents of the University of California
   
   Uděluje se oprávnění k užití, rozmnožování, provádění úprav a
   rozšiřování tohoto softwaru a dokumentace k němu, pro jakékoli účely,
   bez licenčního poplatku a bez písemné licenční smlouvy, za podmínky,
   že na všech jeho kopiích je uvedeno oznámení o výše uvedených právech,
   jakož i obsah tohoto a dvou následujících odstavců.
   
   THE UNIVERSITY OF CALIFORNIA ("KALIFORNSKÁ UNIVERZITA") NENÍ V ŽÁDNÉM
   PŘÍPADĚ ODPOVĚDNA ŽÁDNÉ TŘETÍ OSOBĚ ZA PŘÍMOU, NEPŘÍMOU, ZVLÁŠTNÍ,
   NAHODILOU NEBO VÝSLEDNOU ŠKODU, VČETNĚ UŠLÉHO ZISKU, ZPůSOBENOU UŽITÍM
   TOHOTO SOFTWARU A DOKUMENTACE K NĚMU, A TO I V PŘÍPADĚ, ŽE THE
   UNIVERSITY OF CALIFORNIA BYLA INFORMOVÁNA O MOŽNOSTI VZNIKU TAKOVÉ
   ŠKODY.
   
   HE UNIVERSITY OF CALIFORNIA ZEJMÉNA NEPOSKYTUJE JAKÉKOLI ZÁRUKY, A TO
   NEJEN ZÁRUKY OBCHODOVATELNOSTI A VHODNOSTI TOHOTO VýROBKU KE
   SPECIFICKýM ÚČELůM. NÍŽE UVEDENý SOFTWARE JE POSKYTNUT "JAK STOJÍ A
   LEŽÍ" A THE UNIVERSITY OF CALIFORNIA NENÍ POVINNA ZAJISTIT JEHO
   ÚDRŽBU, PODPORU, AKTUALIZACI, VYLEPŠENÍ NEBO MODIFIKACI.
   
   Výše uvedené je BSD licence, běžná licence otevřeného zdroje. Není zde
   žádné omezení ohledně užití kódu zdroje. Jsme s tím spokojeni a nemáme
   v úmyslu na této skutečnosti cokoli měnit.
   
    1.3) Na kterých Unixex lze spustit PostgreSQL?
    
   PostgreSQL běží na všech moderních unixových platformách. V
   instalačních instrukcích naleznete aktuální seznam všech platforem na
   kterých byla testováním ověřena funkcionalita PostgreSQL.
   
    1.4) Které ne-unixové platformy jsou podporované?
    
   Klient
   
   Knihovna libpq, psql a některé další moduly byly přeloženy pro MS
   Windows. Klienta lze provozovat na MS Windows, ten prostřednictvím
   TCP/IP protokolu komunikuje se serverem běžícím na některé z
   podporovaných Unixových platforem. K překladu lze použít win32.mak a
   Win32 knihovny libpq a psql. K databázi PostgerSQL lze přistupovat
   skrze rozhraní ODBC.
   
   Server
   
   Server může být na WindowsNT a Win2k provozován pouze s knihovnou
   Cygwin, Cygnus Unix/NT porting library. Více pgsql/doc/FAQ_MSWIN v
   distribuci nebo MS Windows FAQ na adrese
   http://www.PostgreSQL.org/docs/faqs/text/FAQ_MSWIN.
   
   Na nativním portu pro MS Win NT/2000/XP se pracuje. Další informace o
   aktuálním stavu PostgreSQL pro Windows naleznet na adrese
   http://techdocs.postgresql.org/guides/Windows a
   http://momjian.postgresql.org/main/writings/pgsql/win32.html.
   
   Existující port pro Novell Netware 6 naleznete na
   http://forge.novell.com.
   
    1.5) Kde mohu získat PostgreSQL?
    
   Primárním anonymním ftp serverem pro PostgreSQL je
   ftp://ftp.PostgreSQL.org/pub. Seznam zrcadel naleznete na našich
   webových stránkách.
   
    1.6) Kde mohu získat podporu?
    
   Hlavní mailová konference je: pgsql-general@PostgreSQL.org. Slouží k
   diskuzím ohledně PostgreSQL. Přihlásíte se zasláním mailu obsahující
   následující řádky v těle dopisu (nikoliv v záhlaví - subjectu):
    subscribe
    end

   na adresu pgsql-general-request@PostgreSQL.org.
   
   Můžete si vyžádat denní přehled (diggest), který má zhruba 30K denně
   zpráv.
   
   Konference psql-bugs je určena k zasílání zpráv o chybách. Pro
   přihlášení pošlete mail se stejným obsahem jako v předchozím případě
   na adresu pgsql-bugs-request@PostgreSQL.org.
   
   Do vývojářské konference se přihlásíte odesláním dopisu s již
   zmiňovaným obsahem na mailto:pgsql-hackers-request@PostgreSQL.org.
   
   Seznam dalších konferencí naleznete na stránkách PostgreSQL:
   
     http://www.postgresql.org
     
    1.7) Jaká je poslední verze?
    
   Poslední verze PostgreSQL je 7.4.3. Plánujeme uvolnit významnou verzi
   každých šest až osm měsíců.
   
    1.8) Jaká je dostupná dokumentace?
    
   Různé manuály, manuálové stránky a několik malých testovacích příkladů
   jsou součásti distribuce. Podívejte se do adresáře /doc. Manuály jsou
   přístupné online na http://www.PostgreSQL.org/docs.
   
   Na adresách http://www.PostgreSQL.org/docs/awbook.html a
   http://www.commandprompt.com/ppbook/ naleznezte dvě online knihy o
   PostgreSQL. Seznam dostupné literatury je na
   http://techdocs.PostgreSQL.org/techdocs/bookreviews.php. Soubor
   technických článků s tematikou PostgresQL najdete na
   http://techdocs.PostgreSQL.org/.
   
   psql má užitečný metapříkaz \d sloužící k zobrazení informací o
   typech, operátorech, funkcí, agregačních funkcí atd.
   
   Více dokumentace naleznete na našich webových stránkách.
   
    1.9) Kde najdu seznam známých chyb nebo nepodporovaných vlastností?
    
   PostgreSQL podporuje rozšířenou podmnožinu SQL-92. V našem TODO
   najdete seznam známých chyb, chybějících vlastností a seznam
   vlastností, které budou do systému implementovány v budoucnu (včetně
   priorit).
   
    1.10) Jak se mohu naučit SQL?
    
   V knize The PostgreSQL book na
   http://www.PostgreSQL.org/docs/awbook.html je vysvětlen jazyk SQL
   (vyšla česky). Další dostupnou knihou je
   http://www.commandprompt.com/ppbook. Kvalitní návody naleznete na
   http://www.intermedia.net/support/sql/sqltut.shtm, a na
   http://sqlcourse.com.
   
   Další je Teach Yourself SQL in 21 days, Second Edition na
   http://members.tripod.com/er4ebus/sql/index.htm.
   
   Mnoho uživatelů doporučuje The Practical SQL Handbook, Bowman, Judith
   S., et al., Addison-Wesley. Jiní preferují The Complete Reference SQL,
   Groff et al., McGraw-Hill.
   
    1.11) Nemá PostgreSQL problémy s rokem 2000?
    
   Nemá, můžeme pracovat s datumy po roce 2000 našeho letopočtu i před
   rokem 2000 př.n.l.
   
    1.12) Jak se připojit k vývojářskému týmu?
    
   Nejdříve si stáhněte nejnovější zdroje a přečtěte si vývojářskou
   dokumentaci na našem webu nebo v distribuci. Pak se přihlašte do
   konferencí pgsql-hackers a pgsql-patches. Kvalitní záplaty posílejte
   do pgsql-patches.
   
   Právo commit má v CVS archivu asi třinácti lidí. Každý z nich poslal
   mnoho kvalitních záplat, takže tehdejší commiters měli jistotu, že
   budou předkládat jenom kvalitní záplaty a mohli jim předělit větší
   práva.
   
    1.13) Kam podat report o chybě?
    
   Navštivte naši PostgreSQL BugTool stránku na
   http://www.PostgreSQL.org/bugs/bugs.php, která obsahuje návod a
   směrnice jak podat chybový report.
   
   Ověřte si na našem ftp serveru ftp://ftp.PostgreSQL.org/pub, zda-li
   máte nejnovější verzi PostgreSQL a zda-li k ní neexistují nějaké
   záplaty.
   
    1.14) Jak je na tom PostgreSQL v porovnání s jinými databázemi?
    
   Existuje několik hledisek jak porovnávat software: vlastnosti, výkon,
   spolehlivost, podpora a cena.
   
   Vlastnosti
          PostgreSQL má hodně společných vlastností s velkými komerčními
          DBMS, např. transakce, vnořené dotazy, spouště, pohledy,
          kontrolu referenční integrity a sofistikované zamykání.
          Podporuje některé vlastnosti, které tyto systémy nemají,
          uživatelem definované typy, dědičnost, pravidla, MVCC
          redukující zamykání.
          
   Výkon
          Výkonnostně je na tom PostgreSQL podobně jako další komerční
          ale i open source databáze, v něčem je rychlejší, jindy
          pomalejší. V porovnání s MySQL a podobnými databázovými systémy
          je PostgreSQL rychlejší při víceuživatelském přístupu,
          složitějších dotazech a zatížení read/write dotazy. MySQL je
          rychlejší v jednodušších dotazech s malým počtem uživatelů.
          Navíc, MySQL nepodporuje mnohé vlatnosti zmíněné v sekci
          vlastnosti. Zapracovali jsme na spolehlivosti a podporovaných
          vlastnostech, a výkon zvyšujeme v každé verzi. Zajímavou
          stránku porovnávající PostgreSQL a MySQL naleznete na
          http://openacs.org/philosophy/why-not-mysql.html. Za vývojem
          MySQL není Open Source komunita, ale komerční společnost,
          přestože svoje produkty distribuuje jako Open Source.
          
   Spolehlivost
          Jsme si vědomi, že databáze musí být spolehlivá, jinak je
          nepoužitelná. Snažíme se zveřejňovat dobře otestovaný, stabilní
          kód s minimem chyb. Každá verze je více než měsíc v beta
          testování, a naše historie verzí ukazuje, že můžeme nabídnout
          stabilní, solidní verze, které jsou připraveny pro reálné
          nasazení. V této oblasti jsme srovnatelní s dalšími databázemi.
          
   Podpora
          Na naší mailové konferenci můžete kontaktovat velkou skupinu
          vývojářů a uživatelů.problémů. Nemůžeme garantovat opravu,
          nicméně komerční databáze také ne vždy nabídnou opravu. Podle
          ohlasů je naše podpora hodnocena lépe než u jiných DBMS a to
          díky přímému kontaktu s vývojáři, velkou komunitou uživatelů,
          kvalitními manuály a přístupným zdrojovým kódem. Pro uživatele,
          kteří vyžadují podporu ke konkrétním případům, existuje placená
          podpora (FAQ sekce 1.6).
          
   Cena
          PosgreSQL lze volně používat pro nekomerční i komerční použití.
          Můžete do svých produktů přidat náš kód bez omezení, respektive
          v souladu s podmínkami naší licenční smlouvy (v duchu BSD
          licence).
          
    1.15) Jak lze finančně pomoci PostgreSQL?
    
   PosgreSQL má prvotřídní infrastrukturu od našeho začátku v roce 1996.
   Vděčíme za to Marku Fournierovi, který založil a spravoval tuto
   infrastrukturu několik let.
   
   Kvalitní infrastruktura je velice důležitá pro každý open source
   projekt. Předchází nedorozuměním, která velice zdržují pokrok v
   projektu.
   
   Tato infrastruktura není laciná. K jejímu zajištění je třeba stále
   hradit určité měsíční a jednorázové částky. Pokud máte Vy nebo Vaše
   společnost peníze, které nám můžete darovat, obraťe se na
   http://store.pgsql.com/shopping/ a darujte je.
   
   Ačkoliv webová stránka zmiňuje PostgreSQL, Inc. vklady jsou určeny
   pouze k podpoře projektu PostgreSQL a nepodporují žádnou existující
   společnost. Pokud to vyžadujete, můžete poslat kontrolu na naši
   kontaktní adresu.
     _________________________________________________________________
   
   Pokud máte příklad úspěšného nasazení PostgreSQL, přihlaště se na náš
   advocacy site na http://advocacy.postgresql.org.
   
                             User client dotazy
                                      
    2.1) Kde naleznu ODBC ovladače pro PostgreSQL?
    
   Pro PostgreSQL existují dva ODBC ovladače - PsqlODBC a OpenLink ODBC.
   
   PsqlODBC je ke stažení na
   http://gborg.postgresql.org/project/psqlodbc/projdisplay.php.
   
   OpenLink můžete získat na http://www.openlinksw.com. Spolupracuje s
   jejich klientským programovým vybavením a je dostupný pro všechny jimi
   podporované platformy (Win, Mac, Unix, VMS).
   
   Tento ovladač je určen pro ty, kteří vyžadují podporu komerční
   kvality, nicméně freeware verze je dostupná a funkční. Dotazy
   zasílejte na postgres95@openlink.co.uk.
   
    2.2) Jaké nástroje lze použít pro PostgreSQL a web?
    
   Pěkný úvod do databázových technologií zabezpečujících chod webových
   stránek najdete na http://www.webreview.com.
   
   Pro tvorbu webu existuje excelentní rozhraní PHP, které naleznete na
   http://www.php.net.
   
   Pro složitější případy se často používá Perl a CGI.pm nebo mod_perl.
   
    2.3) Existuje grafické rozhraní pro PostgreSQL?
    
   Pro PostgreSQL existuje několik grafických rozhraní: PgAccess
   (http://www.php.net), PgAdmin III (http://www.php.net), RHDB Admin
   (http://sources.redhat.com/rhdb/) a Rekall (
   http://www.thekompany.com/products/rekall/). Dále ještě PhpPgAdmin
   (http://phppgadmin.sourceforge.net/) což je rozhraní PostgreSQL
   založené na web technologii.
   
   Úplnější seznam najdete na
   http://techdocs.postgresql.org/guides/GUITools.
   
    2.4) Které programovací jazyky mají podporu pro PostgreSQL?
    
   Většina programovacích jazyků obsahuje rozhraní pro PostgreSQL.
   Podívejte se do rozšiřujících modulů Vašeho programovacího jazyka.
   
   Distribuce PostgreSQL obsahuje tato rozhraní:
     * C (libpq)
     * Embbedded C (ecpg)
     * Java (jdbc)
     * Python (PyGreSQL)
     * TCL (libpgtcl)
       
   Další rozhraní jsou dostupná na http://gborg.postgresql.org v sekci
   Drivers/Interfaces.
     _________________________________________________________________
   
                           Administrativní dotazy
                                      
    3.1) Jak nainstalovat PostgreSQL jinam než do /usr/local/pgsql?
    
   Použijte volbu --prefix při spuštění configure.
   
    3.2) Při startu postmaster, dostanu chybové hlášení Bad System Call nebo
    core dump. Proč?
    
   Důvody mohou být různé, ale nejprve zkontrolujte, zda Váš systém
   podporuje System V extensions. PostgreSQL vyžaduje v jádře podporu
   sdílené paměti a semaforů.
   
    3.3) Při startu postmastera dostanu hlášení o chybě IpcMemoryCreate. Proč?
    
   Buďto nemáte správně nakonfigurovanou sdílenou paměť v jádře nebo
   musite zvětšit její velikost. Potřebná velikost je závislá na
   architektuře a na tom, kolik paměťových bufferů a backendů máte
   povoleno pro postmastera. Pro většinu systémů s předdefinovaným počtem
   backendů a paměťových bufferů je minimum zhruba 1MB. V PostgreSQL
   Administrator's Guide naleznete podrobnější informace o sdílené paměti
   a semaforech.
   
    3.4) Při startu postmastera dostanu hlášení o chybě IpcSemaphoreCreate.
    Proč?
    
   Pokud dostane chybovou zprávu IpcSemaphoreCreate: semget failed (No
   space left on device), pak vaše jádro nemá dost volných semaforů.
   PostgreSQL vyžaduje jeden semafor pro každý backend v pozadí. Dočasným
   řešením je start postmaster s limitem backendů. Použijte přepínač -N s
   hodnotou menší než 32. Úplným řešením je zvýšení hodnot SEMMNS a
   SEMMNI jadra.
   
   Nefunkční semafory mohou způsobit pád během intenzivních databázových
   operací.
   
   Pokud se tato chyba vyskytuje ještě někde jinde, možná nemáte vůbec
   nakonfigurovány semafory ve vašem jádře. V PostgreSQL Administrator's
   Guide najdete podrobnější popis požadavků na sdílenou pamět a
   semafory.
   
    3.5) Jak povolit nebo zakázat přístup z jiných stanic?
    
   Při výchozím nastavení PostgreSQL odepře přístup z jiných stanic než
   lokální s použitím UDP. Přístup z jiných strojů není možný dokud jej
   nepovolíte nastavením tcpip_socket v postgresql.conf a určením způsobu
   autentifikace v $PGDATA/pg_hba.conf.
   
    3.6) Jak ladit databázový stroj na lepší výkon?
    
   Určitě pomohou indexy. Příkaz EXPLAIN ANALYZE Vám umožní sledovat jak
   PostgreSQL interpretuje Váš dotaz a které indexy používá.
   
   Při větší dávce INSERTů uvažujte o náhradě příkazem COPY. Ten je
   mnohem rychlejší nežli samotný INSERT. Každý příkaz mimo blok BEGIN
   WORK/COMMIT se provádí ve vlastní transakci. Zvažte, zda-li by se
   nedalo několik příkazů spojit do jedné transakce. Tím se sníží režie
   na transakce. Před provedením rozsáhlých změn zrušte indexy, které po
   dokončení změn opět vytvořte.
   
   Máte několik dalších možností, jak zlepšit výkon. Můžete zakázat
   fsyn() při startu postmastera přepínači -o -F. Tyto přepínače zabrání
   fsync(), tj. zápisu na disk po každé transakci.
   
   Můžete zvýšit velikost paměťových bufferů použitých backendy tj.
   parametr -B postmasteru. Pokud ale tato hodnota bude příliš velká, tak
   možná nespustíte postmastera jelikož dosáhnete limitu sdílené paměti.
   Každý buffer má 8K a implicitně je 64 bufferů.
   
   Dále můžete použít přepínač -S k zvýšení limitu paměti pro backendy na
   dočasné třídění. Hodnota je míněna v kilobytech a výchozí nastavení je
   512, tj. 512K.
   
   Můžete použít příkaz CLUSTER, který uspořádá fyzicky data v tabulkách
   podle indexu. Více na manuálových stránkách příkazu CLUSTER.
   
    3.7) Jaké jsou možnosti ladění?
    
   Máte několik možností jak se dostat k užitečným stavovým informacím.
   
   Zaprvé, při překladu použijte přepínač --enable-cassert, tím se zapne
   monitorování a následné zastavení aplikace, když se proces v backendu
   dostane do neočekávaného stavu.
   
   Jak postmaster tak postgres má několik přepínačů umožňujících ladění.
   Postmaster nastartujte tak, abyste si byli jisti, že je standartní
   výstup a standartní chybový výstup přesměrován do souboru logu,
   například:
    cd /usr/local/pgsql
    ./bin/postmaster > server.log 2>&1 &

   Tím se vytvoří log v adresáři PostgreSQL, Tento soubor obsahuje
   užitečné informace o problémech a chybách vyskytlých se na serveru.
   Postmaster má přepínač -d určující, jak podrobné mají být reportované
   informace, tj. debug level. Pozor, při velké hodnotě debug levelu
   rychle roste velikost souboru logu.
   
   Pokud neběží postmaster, můžete spustit backend PostgreSQL z příkazové
   řádky a napsat svůj SQL dotaz přímo v backendu (doporučeno pouze pro
   ladění). Dotaz je v tomto případě ukončen novou řádkou, nikoliv
   středníkem. Pokud máte aplikaci přeloženou s ladícími symboly, můžete
   použít debbuger k monitorování procesu. Pokud není backend spuštěn
   postmasterem, pak neběží ve svém obvyklém prostředí a tudíž některé
   problémy dané interakcí mezi backendy nemohou být nasimulovány.
   
   Pokud běží postmaster, spusťe psql v jednom okně a pak si zjistěte PID
   procesu postgres použitého psql. V debuggeru sepřipojte k postgresql
   PID. Pak nastavte breakpointy v debuggeru a zadejte dotaz v psql.
   Pokud ladíte startup postgresu, pak nastavte PGOPTIONS="-W n" a spusťe
   psql. Tento přepínač způsobí pauzu n sekund, takže budete mít čas se
   připojit k procesu, a nastavit breakpointy a pokračovat v startup
   posloupnosti.
   
   Pro ladění a měření výkonu mohou být užitečné přepínače -s, -A a -t
   programu postgres (backend).
   
   Můžete provést překlad s profilací, tak abyste viděli kolik času
   zabírají jednotlivé funkce. Soubory s profily backendů jsou uloženy v
   adresáři pgsql/data/base/dbname. Profil klienta pak v jeho aktuálním
   adresáři. Korektní profilace v prostředí Linux požaduje konfiguraci
   systému s parametrem -DLINUX_PROFILE.
   
    3.8) Proč dostanu "Sorry, too many clients", když se zkouším připojit?
    
   Zvyšte limit postmastera na maximální počet současně spuštěných
   backendů.
   
   Výchozí hodnota je 32 backendů. Tuto hodnotu zvýšíte zastavením a
   opětovným spuštěním postmastera s parametrem -N nebo úpravou
   postgresql.conf.
   
   Při zvýšení hodnoty -N nad 32 musíte zvýšit hodnotu -B nad výchozí 64,
   -B musí být minimálně dvakrát větší, nebo ještě lépe více.
   Pravděpodobně zjistíte, že pro velký počet procesů backendu je nutné
   zvýšit některé parametry jádra. Jsou to především maximální velikost
   sdílené paměti SHMMAX, maximální počet semafórů SEMMNS a SEMMNI,
   maximální počet procesů NPROC, maximální počet procesů uživatele
   MAXUPRC a maximální počet otevřených souborů NFILE a NINODE. Důvod pro
   omezení maximálního počtu backendů je fakt, že by mohlo dojít k
   vyčerpání zdrojů Vašeho systému.
   
    3.9) K čemu slouží adresář pgsql_tmp?
    
   Tento adresář obsahuje dočasné soubory vytvořené exekutorem dotazů.
   Například, když je nutné třídění k zajištění ORDER BY a třídění má
   větší nároky na prostor než povoluje parametr -S backendu, pak je
   vytvořen dočasný soubor k uložení extra údajů.
   
   Dočasné soubory jsou obvykle mazány automaticky, ale může se stát, že
   během třídění server spadne. Zastavení a další start postmastera
   zajistí odstranění souborů s těchto adresářů.
   
    3.10) Proč je požadováno dump a obnovení (load) databáze během upgrade mezi
    velkými verzemi PostgreSQL?
    
   PostgreSQL se minimálně mění během malých verzí, takže např. při
   upgrade z 7.2 na 7.2.1 není nutné dump a load databáze. Ale výynamné
   verze často mění interní formát systémových tabulek a datových
   souborů. Tyto změny jsou natolik rozsáhlé, že nelze zajistit zpětnou
   kompatibilitu pro datové soubory. Dump uloží data v obecném formátu,
   takže mohou být načtena a používána v novém interním formátu.
     _________________________________________________________________
   
                              Provozní dotazy
                                      
    4.1) Čím se liší binární a normální kurzor?
    
   Popis najdete v manuálové stránce DECLARE
   
    4.2) Jak získat pouze první řádek dotazu? Náhodný řádek?
    
   Podívejte se do man. stránky příkazu FETCH, nebo použijte SELECT ...
   LIMIT ...
   
   I když potřebujete získat pouze prvních několik řádků, je třeba
   zpracovat všechna data, např. pokud dotaz má ORDER BY. Pokud však
   existuje index, který odpovídá ORDER BY, PostgreSQL může získat pouze
   prvních n řádků a ukončit zpracování dotazu.
   
   K získání náhodného řádku použijte:
    SELECT col
    FROM tab
    ORDER BY random()
    LIMIT 1;

    4.3) Jak získám seznam tabulek nebo jinak jak jej získá psql?
    
   Příkaz \dt v psql zobrazí seznam tabulek. Úplný seznam příkazů psql
   dostanete příkazem \?. Také se můžete podívat do zdrojových kódů psql
   do souboru pgsql/src/bin/psql/describe.c. Ten obsahuje SQL příkazy,
   které se používají v psql metapříkazech. Dále můžete spustit psql s
   přepínačem -E, který způsobí zobrazení každého dotazu, které
   zpracování metapříkazu vyvolá. PostgreSQL nabízí SQLi INFORMATION
   SCHEMA s tabulkami obsahující informace o databázi.
   
    4.4) Jak odstraním sloupec tabulky, jak změním jeho typ?
    
   Počínaje verzí 7.3 můžete použít příkaz ALTER TABLE DROP COLUMN. Ve
   starších verzích můžete použít následující postup:
    BEGIN;
    LOCK TABLE old_table;
    SELECT ... -- mimo sloupec, který chceme odstranit
    INTO TABLE new_table;
    DROP TABLE old_table;
    ALTER TABLE new_table RENAME TO old_table;
    COMMIT;

   Pro změnu typu sloupce je třeba provést:
    BEGIN;
    ALTER TABLE tab ADD COLUMN new_col new_data_type;
    UPDATE tab SET new_col = CAST(old_col AS new_data_type;
    ALTER TABLE tab DROP COLUMN old_col;
    COMMIT;

   Poté proveďte VACUUM FULL tab - uvolníte tím diskový prostor zabraný
   nyní již neplatnými řádky.
   
    4.5) Jaká je maximální velikost řádku, tabulky a databáze?
    
   PostgreSQL má tato omezení:
    Maximální velikost databáze:           neomezena (existují 32TB db)
    Maximálné velikost tabulky:            32 TB
    Maximální velikost řádky:              1.6 TB
    Maximální velikost položky             1 GB
    Maximální počet řádků v tabulce:       neomezeno
    Maximální počet sloupců v tabulce:     250-1600 podle typů
    Maximální počet indexů na tabulce:     neomezeno

   Ve skutečnosti nic není neomezeno, limitem bývá vždy dostupná disková
   paměť nebo velikost operační paměti. Pokud máte některou z těchto
   hodnot neobvykle velkou, může dojít ke snížení výkonu.
   
   Maximální velikost tabulky je 32 TB a nevyžaduje podporu velkých
   souborů operačním systémem. Velké tabulky se ukládají do několika 1 GB
   souborů takže limity souborového systému nejsou podstatné.
   
   Maximální velikost tabulky a maximální počet sloupců můžeme
   zečtyřnásobit nastavením velikosti bloku na 32K.
   
    4.6) Kolik diskového prostoru je potřeba k uložení dat z
    
   normálního textového souboru?
   
   PostgreSQL vyžaduje až pětinásobek diskového prostoru k uložení dat z
   textového souboru.
   
   Například, uvažujme soubor se 100 tisíci řádky obsahující na každé
   řádce celé číslo a textový popis. Text je v průměru dvacet bytů
   dlouhý. Textový soubor bude 2.8 MB dlouhý. Velikost databáze
   obsahující odpovídající data bude zhruba 6.4 MB.
    36 bytů: hlavička řádku (přibližně)
    24 bytů: jedna celočíselná položka a jedna textová
   + 4 byty: ukazatel na stránku k ntici
   ------------------------------------------------------
    64 bytů na řádek

   Velikost datové stránky PostgreSQL je 8KB

    8192 bytů na stránce
    ---------------------- = 128 řádek na stránku
      64 bytů za řádek

    100000 řádek
    -------------------- = 782 stránek (zaokrouhleno nahoru)
       128 řádek na stránce

    782 * 8192 = 6, 406, 144 bytů (6.4 MB)

   Indexy nemají tak velkou režii, ale mohou být také velké, protože
   obsahují indexovaná data.
   
   Hodnoty NULL jsou uloženy v bitmapách, takže spotřebují jen velmi málo
   diskového prostoru.
   
    4.7) Jak získám seznam vytvořených tabulek, indexů, databází?
    
   psql má sadu metapříkazů k zobrazení těchto informací. Jejich seznam
   získáte příkazem \?. Dále se můžete podívat na obsah systémových
   tabulek začínajících pg_. Spuštění psql s parametrem -l provede výpis
   názvů všech databází.
   
   Soubor pgsql/src/tutorial/syscat.source obsahuje SELECTy přistupující
   k systémovým tabulkámm.
   
    4.8) Můj dotaz je pomalý a nepoužívá vytvořené indexy. Proč?
    
   Každý dotaz nemusí nutně použít existující indexy. Index se použije
   tehdy, když je tabulka větší než určitá minimální velikost, a dotaz
   vybírá pouze procentuálně malou část řádků tabulky. To proto, že
   náhodný přístup k disku daný čtením indexu může být pomalejší než
   lineární čtení tabulky nebo sekvenční čtení.
   
   PostgreSQL rozhoduje o použití indexů na základě statistiky přístupů k
   tabulce. Tyto statistiky se shromažďují příkazy VACUUM ANALYZE nebo
   ANALYZE. Díky statistikám má optimizer informaci o počtu řádek v
   tabulce a může lépe rozhodnout o použití indexů. Statistiky se uplatní
   při určení optimálního pořadí a metody spojení tabulek. Statistiky by
   se měli aktualizovat opakovaně, tak jak se mění obsah tabulek.
   
   Indexy nejsou obyčejně použity pro setřídění nebo spojení tabulek.
   Sekvenční zpracování následované explicitním tříděním je obyčejně
   rychlejší než indexní čtení na velké tabulce.
   
   Jinak je tomu v případě použití LIMIT a ORDER BY, při kterém se
   většinou index použije, výsledkem je pouze malá část tabulky. Funkce
   MAX() a MIN() nepoužívají indexy, ale je možné tutéž hodnotu získat:
    SELECT col
    FROM tab
    ORDER BY col [ DESC ]
    LIMIT 1;

   Pokud si myslíte, že optimizer mylně zvolil sekvenční prohledávání
   tabulky, použijte příkaz SET enable_seqscan TO 'off' a zkuste zda je
   indexní prohledávání rychlejší.
   
   Při vyhledávání na základě vzoru jako je např. operátor LIKE nebo ~ se
   indexy použíjí pouze za určitých skutečností:
     * začátek hledaného vzoru musí být ukotven k začátku, tj.
          + vzor LIKE nesmí začínat %
          + ~ regulární výraz musí začínat ^
     * vzor nesmí začínat intervalem, např. [a-e]
     * vyhledávaní, které není Case sensitiv jako je ILIKE nebo ~*
       nepoužívá indexy. Můžete ale použít funkcionální indexy, které
       jsou posány v sekci 4.12
     * při inicializaci databáze (initdb) musí být použito C locale
       (pozn. překladatele - tudíž v našich podmínkách nepoužitelné,
       nepracovalo by české třídění).
       
    4.9) Jak zjistím, jak optimizer dotazu vyhodnocuje můj dotaz?
    
   Podívejte se do manuálové stránky příkazu EXPLAIN.
   
    4.10) Co to je R-tree index?
    
   R-tree index se používá pro indexování prostorových dat. Hash index
   nemůže obsloužit prohledávání oblastí. B-tree index může řídit
   vyhledání oblastí v jedné dimenzi. R-tree index může podporovat
   hledání v multidimenzionálních datech. Použijeme-li například R-tree
   index na atributy typu point, pak systém může efektivně odpovědět na
   dotaz - vyber všechny body uvnitř obdélníků.
   
   Původní návrh R-tree je Guttman, A. "R-trees: A Dynamic Index
   Structure for Spatial Searching." Proceedings of the 1984 ACM SIGMOD
   Int'l Conf on Mgmt of Data, 45-57
   
   Tyto materiály naleznete v Stonebraker's "Readings in Database
   Systems".
   
   Vestavěné R-tree může sloužit k indexaci polygonů a oblastí.
   Teoreticky můžeme R-tree použít i pro více dimenzí (jiné než 3D). Ve
   skutečnosti ale takové rozšíření R-tree vyžaduje trochu práce a ve
   součastnosti chybí dokumentace jak na to.
   
    4.11) Co je Genetic Query Optimizer?
    
   GEQO modul urychluje optimalizaci dotazů při spojování množství
   tabulek metodou Genetických algoritmů (GA). To umožňuje získat velkého
   množství variant spojení při neúplném prohledáváním.
   
    4.12) Jak provést vyhledávání regulárního výrazu case sensitiv, insensitiv?
    Jak použít index pro case insensitive vyhledávání?
    
   Operátor ~ slouží k porování s regulárním výrazem, jeho modifikace *~
   představuje case insensitive vyhledávání. Jedná se o obdobu LIKE a
   ILIKE.
   
   Pro vyhledávání bez ohledu na velká malá písmena použijeme:
    SELECT *
    FROM tab
    WHERE lower(col) = 'abc';

   V tomto případě se nepoužije standardní index. Nicméně, použije se
   funkcionální index, pokud jej vytvoříte:
    CREATE INDEX tabindex ON tab (lower(col));

    4.13) Jak v dotazu detekovat, že položka je NULL?
    
   Určíte pomocí IS NULL nebo IS NOT NULL
   
    4.14) Jaké jsou rozdíly mezi různými znakovými typy?
    
Typ         Interní název       Poznámka
--------------------------------------------------------------------------
VARCHAR(n)  varchar             omezeno maximální délkou, bez doplnění mezerami
CHAR(n)     bpchar              řetězec je doplněn mezerami do dané délky
TEXT        text                bez horního limitu na délku
BYTEA       bytea               pole bytů (bezpečně lze uložit i znak NULL)
"char"      char                jeden znak

   S interními názvy se setkáte v systémovém katalogu a v některých
   chybových hlášeních.
   
   První čtyři uvedené typy jsou tzv. varlena typy (tj. první čtyři byty
   na disku nesou údaj o délce, následují samotná data). Proto skutečný
   použitý prostor je vždy o něco málo větší než deklarovaná délka.
   Naopak, tyto datové typy jsou komprimovánty TOASTem, takže prostor na
   disku může být nižší než je očekáváno.
   
   VARCHAR(n) je vhodný pro ukládání textů promměné délky s pevně
   stanovenou maximální délkou. TEXT je pro řetězce bez omezení délky s
   maximem jeden gigabajt.
   
   CHAR(n) slouží k ukládání řetězců stejné délky. CHAR(n) doplní prázdné
   znaky do specifikované délky, zatímco VARCHAR(n) uloží pouze předané
   znaky. BYTEA je určeno pro ukládání binárních dat, včetně NULL byte.
   Všechny zde popsané typy mají podobné výkonnostní charakteristiky.
   
    4.15.1) Jak vytvořit serial/auto-increment pole?
    
   PostgreSQL podporuje typ SERIAL. Při jeho použití se automaticky
   vytvoří SEQUENCE. Například:
    CREATE TABLE person (
        id   SERIAL,
        name TEXT
    );

   je automaticky převedeno do
    CREATE SEQUENCE person_id_seq;
    CREATE TABLE person (
        id   INT4 NOT NULL DEFAULT nextval('person_id_seq'),
        name TEXT
    );
    CREATE UNIQUE INDEX person_id_key ON person(id);

   Viz dokumentace create_sequence v manuálových stránkách. Dále můžete
   použít unikátní hodnotu OID každého řádku. Potom ale musíte spouštět
   pg_dump s přepínačem -o, tak aby zůstaly zachovány hodnoty OID (u
   příkazu copy COPY WITH OIDS).
   
    4.15.2) Jak získat hodnotu SERIAL po vložení řádku?
    
   Jednou z možností je získat budoucí hodnotu SERIAL funkcí nextval()
   před samotným vložením a pak ji vložit explicitně. Například v jakémsi
   pseudojazyku:
    newid = execute("SELECT nextval('person_id_seq')");
    execute("INSERT INTO person (id, name) VALUES (new_id, 'Blaise Pascal')");

   Můžete pak ještě použít hodnotu newid v dalších dotazech, např. jako
   hodnotu cizího klíče. Název automaticky vytvořené sekvence je
   tabulka_sloupec_seq.
   
   Alternativně můžete získat hodnotu posledně generovou sekvencí funkcí
   currval() po vložení:
    execute("INSERT INTO person (name) VALUES ('Blaise Pascal')");
    new_id = execute("SELECT currval('person_id_seq')");

   Konečně můžete použít OID hodnotu vrácenou příkazem INSERT, ale to je
   pravděpodobně nejméně přenositelné řešení. V Perlu při použití DBI
   modulu Edmunda Mergleho DBD:Pg oid hodnotu získáme
   $sth->{pg_oid_status} po každém $sth->execute().
   
    4.15.3) Nepovede currval() a nextval() k rozhození podmínek při souběhu s
    jinými uživateli?
    
   Nikoliv, currval() vrací hodnotu naposledy generovanou ve vašem
   backendu, a ta tudíž není společná všem uživatelům.
   
    4.15.4) Proč není vygenerované číslo použito při přerušení transakce? Proč
    vznikají díry v číslování vlastní sekvencí/SERIAL sloupce?
    
   K zajištění efektivnosti souběhu, jsou hodnoty posloupnosti, když se o
   ně požádá, a sekvence není zamčena do ukončení transakce. To způsobuje
   díry v číslování ze zrušených transakcí.
   
    4.16) Co to je OID? Co je to TID?
    
   Každý řádek vytvořený v PostgreSQL získá jedinečné OID. Všechna OID
   generovaná během inicializace databáze jsou menší než 16384
   (include/access/transam.h). Všechna OID generovaná na požadavek
   uživatele jsou rovna nebo vyšší této hodnotě. Normálně, všechna OID
   jsou jedinečná nejen uvnitř tabulky nebo databáze, ale v rámci celé
   instalace PostgreSQL
   
   PostgreSQL používá OID ve svém interním systému tabulek k vytvoření
   relací. Tato OID mohou být použita k identifikaci konkrétního
   uživatele a použita v spojení. Pro OID hodnoty je doporučen typ OID.
   Nad tímto sloupcem můžete vytvořit index pro urychlení přístupu.
   
   OID jsou dána všem řádkům z centrální oblasti a jsou použita v každé
   databázi. Pokud potřebujete změnit OID, nebo chcete zkopírovat tabulku
   s původními OID, lze použít:
        CREATE TABLE new_table(old_oid oid, mycol int);
        SELECT old_oid, mycol INTO new FROM old;
        COPY new TO '/tmp/pgtable';
        DELETE FROM new;
        COPY new WITH OIDS FROM '/tmp/pgtable';

   OID jsou uložena jako 4bajtový integer a přetečou po čtyřech
   miliardách. Nebylo hlášeno, že by se tak někdy stalo, přesto ale
   plánujeme odstranit tento limit dřív než se tak stane.
   
   TID se používají i identifikaci fyzických řádků s hodnotou bloku a
   offsetu. TIDs se mění modifikací řádků (používá se jako ukazatel
   indexu fyzického řádku).
   
    4.17) Jaký je význam některých výrazů použitých v PostgreSQL?
    
   V některých zdrojových kódech nebo starší dokumentaci se můžete setkat
   s následujícími výrazy, které mají širší význam. Zde je příklad
   nekterých:
     * tabulka, relace, třída (table, relation, class)
     * řádek, záznam, ntice (row, record, tuple)
     * sloupec, položka, atribut (column, field, attribute)
     * vyhledání, výběr (retrieve, select)
     * náhrada, úprava (replace, update)
     * přidání, vkládání (append, insert)
     * OID, serial value (OID, serial value)
     * portal, kurzor (portal, cursor)
     * range variable, jméno tabulky, alias tabulky (range variable,
       table name, table alias)
       
   seznam těchto výrazů můžete nalézt na
   http://hea-www.harvard.edu/MST/simul/software/docs/pkgs/pgsql/glossary
   /glossary.html.
   
    4.18) Proč jsem získal chybové hlášení "ERROR: Memory exhausted in
    AllocSetAlloc()"?
    
   Pravděpodobně došlo k vyčerpání virtuální paměťi na Vašem systému,
   nebo jádro má nízký limit pro určité zdroje. Vyzkoušejte před startem
   posmatera
    ulimit -d 262144
    limit datasize 256m

   Záleží na Vašem shellu, zda budou tyto příkazy úspěšné, měly by zvýšit
   limit datového segmentu pro Vaše procesy a umožnit tak dokončení
   dotazu. Tyto příkazy se aplikují na aktuální proces a všechny synovské
   procesy vytvořené po provedení příkazu. Pokud máte problémy s SQL
   klientem protože backend vrací příliš mnoho dat, zkuste zvýšit limity
   před startem klienta.
   
    4.19) Jak se dozvím, kterou verzi PostgreSQL používám?
    
   V psql spusťte SELECT version();
   
    4.20) Proč operace s velkými objekty končí "invalid large obj descriptor"?
    
   Všechny operace s velkými objekty - lo_open, lo_close, ... musíte
   spouštět v transakci, tj. mezi příkazy BEGIN WORK a COMMIT.
   
   PostgreSQL uvolňuje handle velkých objektů při skončení transakce.
   Pokud budete pracovat s velkými objekty mimo transakci, pravděpodobně
   dostanete toto chybové hlášení, protože handle již budou neplatné.
   Pokud používáte interface podobné ODBC musíte nastavit set auto_commit
   off.
   
    4.21) Jak vytvořit sloupec obsahující implicitně aktuální datum?
    
   Použijte CURRENT_TIMESTAMP:

CREATE TABLE test (x int, modtime timestamp DEFAULT CURRENT_TIMESTAMP );

    4.22) Proč jsou moje vnořené dotazy používající IN tak pomalé?
    
   Dřívější verze (před 7.4) spojovali vnořené dotazy k vnějším
   sekvenčním čtením výsledku poddotazu pro každý řádek vnějšího dotazu.
   Pokud poddotaz vrátil několik málo řádků IN bylo rychlé. Pro ostatní
   případy je vhodné nahradit IN EXISTS:
    SELECT *
    FROM tab
    WHERE col IN (SELECT subcol FROM subtab);

   na:
   SELECT *
   FROM tab
   WHERE EXISTS (SELECT subcol FROM subtab WHERE subcol = col);

   Pro urychlení vytvořete index pro subcol.
   
   Ve verzi 7.4 a pozdějších, IN používá stejně sofistikovanou techniku
   spojování tabulek jako ostatní dotazy a je preferovaný před EXISTS.
   
    4.23) Jak provést vnější spojení (outer join)?
    
   PostgreSQL podporuje vnější spojení tabulek standardními SQL příkazy.
   Zde jsou dva příklady:
    SELECT *
    FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);

   nebo
    SELECT *
    FROM t1 LEFT OUTER JOIN USING (col);

   Tyto identické dotazy napojí t1.col na t2.col a ještě přidá
   nepřipojené řádky z t1 (které nemají obdoby v t2). Pravé spojení
   (RIGHT JOIN) přidá nepřipojené řádky z t2. FULL JOIN vrátí všechny
   řádky, včetně nepřipojených z tbulek t1 a t2. Klíčové slovo OUTER je
   nepovinné a váže se na LEFT, RIGHT a FULL join. Běžné spojení se
   nazývá INNER JOIN.
   
   V dřívějších verzích se vnější spojení tabulek mohlo simulovat pomocí
   UNION a NOT IN. Například pro spojení tabulek tab1 a tab2, je
   následující dotaz ekvivalentní k vnějšímu spojení dvou tabulek:
    SELECT tab1.col2, tab2.col2
    FROM tab1, tab2
    WHERE tab1.col1 = tab2.col1
    UNION ALL
    SELECT tab1.col2, NULL
    FROM tab1
    WHERE tab1.col1 NOT IN (SELECT tab2.col1 FROM tab2)
    ORDER BY col1;

    4.24) Jak provést dotaz z více databází?
    
   PostgreSQL nepodporuje dotazy do jiné než aktuální databáze.
   
   contrib/dblink nabízí funkce umožňující provedení dotazu v jiné
   databázi. Klient si může otevřít simultální připojení do různých db
   bez omezení.
   
    4.25) Může funkce vrátit více řádků nebo sloupců?
    
   V PostgreSQL 7.3 můžete jednoduše vracet více řádků nebo sloupců z
   funkce, viz:
   http://techdocs.postgresql.org/guides/SetReturningFunctions.
   
    4.26) Proč nelze spolehlivě vytvářet a rušit dočasné tabulky v PL/pgSQL
    funkcích?
    
   Přeložený kód PL/pgSQL funkce je uložen ve vyrovnávací paměti, tj.
   funkce je překládána pouze při změně kódu, nikoliv před každým voláním
   funkce. Nechtěným vedlejším efektem je, že volání funkce selže, když
   se funkce odkazuje na dočasnou tabulku, pokud tato tabulka byla od
   překladu funkce zrušena (ačkoliv již byla znovu vytvořena a existuje).
   Jediným řešením problému je přístup k dočasné tabulce pomocí EXECUTE,
   tj. dynamické provádění dotazu. Tento příkaz zajistí opakovaný překlad
   dotazu při každém volání funkce.
   
    4.27) Jaké jsou možnosti replikace databází?
    
   Existuje několik dostupných řešení master/slave replikací, tj umožňují
   modifikace master databáze a slave databázím umožňují pouze čtení. Na
   konci http://gborg.PostgreSQL.org/genpage?replication_research najdete
   jejich seznam. Na řešení multi-master replikaci se pracuje na
   http://gborg.PostgreSQL.org/project/pgreplication/projdisplay.php.
   
    4.28) Jaké jsou možnosti šifrování databází?
    
     * contrib/pgcrypto obsahuje šifrovací funkce použitelné v SQL
       dotazech.
     * K šifrování přenosu dat z klienta na server, musí být server
       přeložen s podporou ssl a přepínač ssl v postgresql.conf musí být
       nastaven na hodnotu true. Klient musí mít vytvořen záznam hostssl
       v pg_hba.conf a také mít povolen režim ssl. Lze použít i jiné
       prostředky, nejen nativní podporu ssl v PostgreSQL, např. stunel a
       ssh.
     * Hesla uživatelů databáze jsou zašifrována počínaje verzí 7.3. Ve
       starších verzích toto chování muselo být vynuceno volbou
       PASSWORD_ENCRYPTION v postgresql.conf
     * Server může běžet na šifrovaném souborovém systému.
     _________________________________________________________________
   
                           Rozšiřování PostgreSQL
                                      
    5.1) Napsal jsem UDF funkci, PostgreSQL však končí dump core?
    
   Problém může být způsoben mnoha okolnostmi. Vyzkoušejte si svoji
   funkci nejdříve v nějaké jednoduché aplikaci.
   
    5.2) Jak mohu přispět nějakými šikovnými datovými typy a funkcemi do
    PostgreSQL?
    
   Pošlete své rozšíření do konference pgsql-hackers, a ono pak možná
   skončí v podadresáři contrib.
   
    5.3) Jak napsat funkci v C vracející ntici?
    
   Funkce vracející tabulky jsou podporované PostgreSQL 7.3 a vyšší pro
   jazyky C, PL/PgSQL a SQL. Více naleznete v The Programmer's Guide.
   Příklady těchto funkcí pro C naleznete v contrib/tablefunc.
   
    5.4) Modifikoval jsem zdrojové soubory. Tato změna nebyla při rekompilaci
    vzata v potaz. Proč?
    
   Makefile nemá informace o závislostech mezi hlavičkovými soubory.
   Musíte provést make clean a pak make. Pokud používáte gcc, můžete
   použít přepínač --enable-depend příkazu configure k automatickému
   řešení závislostí překladačem.