head	1.13;
access;
symbols
	REL7_4_29:1.2.4.1
	REL8_0_25:1.6.4.1
	REL8_1_21:1.7.2.1
	REL8_2_17:1.8.2.1
	REL8_3_11:1.11
	REL7_4_28:1.2.4.1
	REL8_0_24:1.6.4.1
	REL8_1_20:1.7.2.1
	REL8_2_16:1.8.2.1
	REL8_3_10:1.11
	REL7_4_27:1.2.4.1
	REL8_0_23:1.6.4.1
	REL8_1_19:1.7.2.1
	REL8_2_15:1.8.2.1
	REL8_3_9:1.11
	REL7_4_26:1.2.4.1
	REL8_0_22:1.6.4.1
	REL8_1_18:1.7.2.1
	REL8_2_14:1.8.2.1
	REL8_3_8:1.11
	REL8_4_STABLE:1.12.0.2
	REL8_4_0:1.12
	REL8_4_RC2:1.12
	REL8_4_RC1:1.12
	REL8_4_BETA2:1.12
	REL8_4_BETA1:1.12
	REL7_4_25:1.2.4.1
	REL8_0_21:1.6.4.1
	REL8_1_17:1.7.2.1
	REL8_2_13:1.8.2.1
	REL8_3_7:1.11
	REL7_4_24:1.2.4.1
	REL8_0_20:1.6.4.1
	REL8_1_16:1.7.2.1
	REL8_2_12:1.8.2.1
	REL8_3_6:1.11
	REL7_4_23:1.2.4.1
	REL8_0_19:1.6.4.1
	REL8_1_15:1.7.2.1
	REL8_2_11:1.8.2.1
	REL8_3_5:1.11
	REL7_4_22:1.2.4.1
	REL8_0_18:1.6.4.1
	REL8_1_14:1.7.2.1
	REL8_2_10:1.8.2.1
	REL8_3_4:1.11
	REL7_4_21:1.2.4.1
	REL8_0_17:1.6.4.1
	REL8_1_13:1.7.2.1
	REL8_2_9:1.8.2.1
	REL8_3_3:1.11
	REL7_4_20:1.2.4.1
	REL8_0_16:1.6.4.1
	REL8_1_12:1.7.2.1
	REL8_2_8:1.8.2.1
	REL8_3_2:1.11
	REL8_2_7:1.8.2.1
	REL8_3_1:1.11
	REL8_3_STABLE:1.11.0.2
	REL8_3_0:1.11
	REL8_3_RC2:1.10
	REL7_3_21:1.1.2.1
	REL7_4_19:1.2.4.1
	REL8_0_15:1.6.4.1
	REL8_1_11:1.7.2.1
	REL8_2_6:1.8.2.1
	REL8_3_RC1:1.10
	REL8_3_BETA4:1.9
	REL8_3_BETA3:1.9
	REL8_3_BETA2:1.9
	REL8_3_BETA1:1.9
	REL7_3_20:1.1.2.1
	REL7_4_18:1.2.4.1
	REL8_0_14:1.6.4.1
	REL8_1_10:1.7.2.1
	REL8_2_5:1.8.2.1
	REL7_3_19:1.1.2.1
	REL7_4_17:1.2.4.1
	REL8_0_13:1.6.4.1
	REL8_1_9:1.7.2.1
	REL8_2_4:1.8.2.1
	REL8_0_12:1.6.4.1
	REL8_1_8:1.7.2.1
	REL8_2_3:1.8.2.1
	REL7_3_18:1.1.2.1
	REL7_4_16:1.2.4.1
	REL8_0_11:1.6.4.1
	REL8_1_7:1.7.2.1
	REL8_2_2:1.8.2.1
	REL8_0_10:1.6.4.1
	REL8_1_6:1.7.2.1
	REL8_2_1:1.8
	REL7_4_15:1.2.4.1
	REL7_3_17:1.1.2.1
	REL8_2_STABLE:1.8.0.2
	REL8_2_0:1.8
	REL8_2_RC1:1.8
	REL8_2_BETA3:1.8
	REL8_2_BETA2:1.8
	REL8_1_5:1.7.2.1
	REL8_0_9:1.6.4.1
	REL7_4_14:1.2.4.1
	REL7_3_16:1.1.2.1
	REL8_2_BETA1:1.8
	REL7_3_15:1.1.2.1
	REL7_4_13:1.2.4.1
	REL8_0_8:1.6.4.1
	REL8_1_4:1.7.2.1
	REL7_3_14:1.1.2.1
	REL7_4_12:1.2.4.1
	REL8_0_7:1.6.4.1
	REL8_1_3:1.7
	REL7_3_13:1.1.2.1
	REL7_4_11:1.2.4.1
	REL8_0_6:1.6.4.1
	REL8_1_2:1.7
	REL7_3_12:1.1.2.1
	REL7_4_10:1.2.4.1
	REL8_0_5:1.6.4.1
	REL8_1_1:1.7
	REL8_1_STABLE:1.7.0.2
	REL8_1_0:1.7
	REL8_1_0RC1:1.7
	REL8_1_0BETA4:1.7
	REL8_1_0BETA3:1.7
	REL7_3_11:1.1.2.1
	REL7_4_9:1.2.4.1
	REL8_0_4:1.6.4.1
	REL8_1_0BETA2:1.7
	REL8_1_0BETA1:1.7
	REL7_3_10:1.1.2.1
	REL7_4_8:1.2.4.1
	REL8_0_3:1.6.4.1
	REL8_0_2:1.6.4.1
	REL7_3_9:1.1.2.1
	REL7_4_7:1.2.4.1
	REL8_0_1:1.6
	REL8_0_STABLE:1.6.0.4
	REL8_0_0:1.6.0.2
	REL8_0_0RC5:1.6
	REL8_0_0RC4:1.6
	REL8_0_0RC3:1.6
	REL8_0_0RC2:1.6
	REL8_0_0RC1:1.6
	REL8_0_0BETA5:1.4
	REL8_0_0BETA4:1.4
	REL7_4_6:1.2.4.1
	REL7_3_8:1.1.2.1
	REL8_0_0BETA3:1.4
	REL8_0_0BETA2:1.4
	REL7_4_5:1.2.4.1
	REL7_3_7:1.1.2.1
	REL7_4_4:1.2.4.1
	REL8_0_0BETA1:1.4
	REL7_4_3:1.2.4.1
	REL7_4_2:1.2.4.1
	REL7_3_6:1.1.2.1
	REL7_4_1:1.2
	REL7_3_5:1.1.2.1
	REL7_4:1.2
	REL7_4_RC2:1.2
	REL7_4_STABLE:1.2.0.4
	REL7_4_RC1:1.2
	REL7_4_BETA5:1.2
	REL7_4_BETA4:1.2
	REL7_4_BETA3:1.2
	REL7_4_BETA2:1.2
	WIN32_DEV:1.2.0.2
	REL7_4_BETA1:1.2
	REL7_3_4:1.1.2.1
	REL7_3_STABLE:1.1.0.2;
locks; strict;
comment	@# @;


1.13
date	2009.07.21.19.20.32;	author petere;	state dead;
branches;
next	1.12;

1.12
date	2009.01.01.17.23.33;	author momjian;	state Exp;
branches
	1.12.2.1;
next	1.11;

1.11
date	2008.01.24.06.23.32;	author petere;	state Exp;
branches;
next	1.10;

1.10
date	2008.01.01.19.45.45;	author momjian;	state Exp;
branches;
next	1.9;

1.9
date	2007.01.05.22.19.20;	author momjian;	state Exp;
branches;
next	1.8;

1.8
date	2006.03.05.15.58.19;	author momjian;	state Exp;
branches
	1.8.2.1;
next	1.7;

1.7
date	2005.03.11.21.46.53;	author momjian;	state Exp;
branches
	1.7.2.1;
next	1.6;

1.6
date	2004.11.30.19.42.37;	author momjian;	state Exp;
branches
	1.6.4.1;
next	1.5;

1.5
date	2004.11.29.03.04.27;	author momjian;	state Exp;
branches;
next	1.4;

1.4
date	2004.07.29.16.30.31;	author momjian;	state Exp;
branches;
next	1.3;

1.3
date	2004.03.02.15.46.22;	author momjian;	state Exp;
branches;
next	1.2;

1.2
date	2003.07.31.04.41.56;	author momjian;	state Exp;
branches
	1.2.4.1;
next	1.1;

1.1
date	2003.06.02.18.16.56;	author momjian;	state Exp;
branches
	1.1.2.1;
next	;

1.1.2.1
date	2003.07.24.00.53.57;	author momjian;	state Exp;
branches;
next	;

1.2.4.1
date	2004.03.02.15.46.34;	author momjian;	state Exp;
branches;
next	;

1.6.4.1
date	2005.03.11.21.47.37;	author momjian;	state Exp;
branches;
next	;

1.7.2.1
date	2006.04.05.22.56.11;	author momjian;	state Exp;
branches;
next	;

1.8.2.1
date	2007.02.01.04.56.41;	author momjian;	state Exp;
branches;
next	;

1.12.2.1
date	2009.07.21.19.21.02;	author petere;	state dead;
branches;
next	;


desc
@@


1.13
log
@Remove translated FAQs

The English FAQ has been moved to the wiki, so the translated versions should
have been removed at that point as well.

The FAQ_MINGW.html should have been removed when the platform FAQs were
integrated into the documentation (or earlier).

applied to both 8.4 and 8.5
@
text
@
                  PostgreSQL iin Ska Sorulan Sorular (SSS)
                                       
   Son gncelleme : 15 Kasm 2004 Pazartesi - 15:03:23
   
   Current maintainer: Bruce Momjian (pgman@@candle.pha.pa.us)
   
   evirenler : Devrim Gndz (devrim@@tdmsoft.com)
   Nicolai Tufar (ntufar@@tdmsoft.com)
   Volkan YAZICI (volkany@@phreaker.net)
   
   Bu belgenin en gncel hali,
   http://www.PostgreSQL.org/docs/faqs/FAQ_turkish.html ve
   http://www.gunduz.org/seminer/pg/FAQ_turkish.html adreslerinde
   grlebilir.
   
   Platforma zel sorularnz, http://www.PostgreSQL.org/docs/index.html
   adresinde yantlanr.
     _________________________________________________________________
   
                               Genel Sorular
                                      
   1.1) PostgreSQL nedir? Nasl okunur?
   1.2) PostgreSQL'in haklar nedir?
   1.3) PostgreSQL, hangi Unix platformlarnda alr?
   1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
   1.5) PostgreSQL'i nereden indirebilirim?
   1.6) Destei nereden alabilirim?
   1.7) En son srm nedir?
   1.8) Hangi belgelere ulaabilirim?
   1.9) Bilinen hatalar ya da eksik zelliklere nereden ulasabilirim?
   1.10) Nasl SQL renebilirim?
   1.11) PostgreSQL 2000 ylna uyumlu mudur?
   1.12) Gelitirme takmna nasl katlabilirim??
   1.13) Bir hata raporunu nasl gnderebilirim?
   1.14) PostgreSQL, dier VTYS(DBMS) lerle nasl karlatrlabilir?
   1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
   
                         Kullanc/istemci Sorular
                                      
   2.1) PostgreSQL iin ODBC srcleri var m?
   2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar
   bulunmaktadr?
   2.3) PostgreSQL'in grafik kullanc arabirimi var mdr?
   2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri
   kullanabilirim?
   
                             Ynetimsel Sorular
                                      
   3.1) PostgreSQL'i /usr/local/pgsql dizininden baka dizinlere nasl
   kurabilirim?
   3.2) Postmaster' balattmda Bad System Call ya da core dumped
   mesaj alyorum. Neden?
   3.3) Postmaster' balattmda, IpcMemoryCreate hatas alyorum.
   Neden?
   3.4) Postmaster', balattmda, IpcSemaphoreCreate hatas alyorum.
   Neden?
   3.5) Dier bilgisayarlarn benim PostgreSQL veritaban sunucuma
   balantlarn nasl kontrol edebilirim?
   3.6) Veritaban motorunu daha iyi baarm icin nasl ayarlayabilirim?
   3.7) Hangi hata ayklama zellikleri bulunmaktadr?
   3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn
   alyorum. Neden?
   3.9) pgsql_tmpdizinin iindeki dosyalar nelerdir?
   3.10) PostgreSQL srmlerini ykseltmek iin neden bir dump/reload
   ilemi gerekletirmek zorundaym?
   3.11) Nasl bir donanm kullanmalym?br>
   
                             letimsel Sorular
                                      
   4.1) Binary cursor ve normal cursor arasndaki fark nedr?
   4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
   4.3) psql'in iinde grdgm tablolarn ya da dier eylerin listesini
   nasl alabilirim?
   4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
   4.5) Bir satr, tablo ve veritaban iin en fazla byklk nedir?
   4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk
   alan gereklidir?
   4.7) Veritabannda hangi tablo ya da index'lerin tanmlandn nasl
   grebilirim?
   4.8) Sorgularm cok yava, ya da index'lerimi kullanmyorlar. Neden?
   4.9) Query-optimizer'n sorgularm nasl deerlendirdiini, ileme
   soktuunu nasl grebilirim?
   4.10) R-tree index nedir?
   4.11) Genetic Query Optimizer nedir?
   4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk
   harfe duyarsz aramalar nasl yapabilirim? Bu byk/kk harfe
   duyarl aramalar iin index'i nasl kullanabilirim?
   4.13) Bir sorguda, bir alann NULL olduunu nasl ortaya
   karabilirim?
   4.14) esitli karakter tipleri arasndaki farklar nelerdir?
   4.15.1) Nasl serial/otomatik artan (auto-incrementing) bir alan
   yaratabilirim?
   4.15.2) Serial giriinin deerini nasl alabilirim?
   4.15.3) currval() ve nextval() dier kullanclara sorun yaratmaz m?
   4.15.4) Neden sequence saylarn transaction ileminin iptalinden
   sonra yeniden kullanlyor? Neden sequence/SERIAL kolonumdaki
   saylarda atlamalar oluyor?
   4.16) OID nedir? TID nedir?
   4.17) PostgreSQL' de kullanlan baz terimlerin anlamlar nelerdir?
   4.18) Neden "ERROR: Memory exhausted in AllocSetAlloc()" hatasn
   alyorum?
   4.19) Hangi PostgreSQL srmn alstrdm nasl grebilirim?
   4.20) Neden large-object ilemlerim, "invalid large obj descriptor"
   hatasn veriyor?
   4.21) u andaki zaman ntanml deer olarak kabul eden kolonu nasl
   yaratrm?
   4.22) Neden IN kullanan subquery'lerim ok yava?
   4.23) Outer join ilemini nasl yapabilirim?
   4.24) Ayn anda birden fazla veritabannda nasl ilem yapabilirim?
   4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?
   4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo
   yaratma/kaldrma ilemlerini yapamyoruz?
   4.27) Hangi ifreleme seenekleri bulunmaktadr?
   
                    PostgreSQL zelliklerini Geniletmek
                                      
   5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm
   zaman neden core dump ediyor?
   5.2) PostgreSQL'e nasl yeni veri tipleri/fonksiyonlar ekleyebilirim?
   5.3) Bir tuple dndrmek iin bir C fonksiyonunu nasl yazarm?
   5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen
   deiiklik geerli olmuyor. Neden?
     _________________________________________________________________
   
                               Genel Sorular
                                      
    1.1) PostgreSQL nedir? Nasl okunur?
    
   PostgreSQL, Post-Gres-Q-L. olarak okunur
   
   PostgreSQL, yeni-nesil VTYS aratrma prototipi olan POSTGRES
   veritaban ynetim sisteminin gelitirilmesidir. POSTGRES'in zengin
   veri tiplerini ve gl veri modelini tutarken, SQL'in gelitirilmi
   alt kmesi olan PostQuel dilini kullanr. PostgreSQL cretsizdir ve
   kaynak kodu ak datlr.
   
   PostgreSQL, PostgreSQL gelitirme listesine ye olan bir Internet
   gelitirici takm tarafndan gelitirilir. u andaki koordinatr,
   Marc G. Fournier (scrappy@@PostgreSQL.org). (Bu takma nasl
   katlacagnz renmek iin 1.6 numaral maddeyi okuyunuz.) Bu takm,
   tm PostgreSQL geliiminden sorumludur.
   
   PostgreSQL 1.01 srmnn yazarlar Andrew Yu ve Jolly Chen idi.
   Bunlarn dnda bir ka kisi de uyarlama, hata ayklama ve kodun
   gelitirilmesi iin alsmt. PostgreSQL'in tredii orijinal
   Postgres kodu, lisans, lisansst ve akademisyenler tarafndan,
   Professor Michael Stonebraker (University of California, Berkeley)
   koordinatrlgnde yazlmtr.
   
   Berkley'deki yazlmn ad Postgres idi. SQL uyumluluu 1995'te
   eklenince, ad Postgres 95 oldu. 1996 ylnn sonlarnda ad
   PostgreSQL olarak deitirildi.
   
    1.2) PostgreSQL'in haklar nedir?
    
   PostgreSQL Data Base Management System
   
   Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
   Portions Copyright (c) 1994-6 Regents of the University of California
   
   Permission to use, copy, modify, and distribute this software and its
   documentation for any purpose, without fee, and without a written
   agreement is hereby granted, provided that the above copyright notice
   and this paragraph and the following two paragraphs appear in all
   copies.
   
   IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY
   FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES,
   INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND
   ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF CALIFORNIA HAS BEEN
   ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   
   THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
   INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
   MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE
   PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF
   CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
   UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
   
   stteki metin klasik ak-kod lisans olan BSD lisansdr. Kaynak
   kodun nasl kullanlabileceine dair snrlamalar yoktur. Bu lisans
   seviyoruz. Deitirme niyetimiz bulunmamaktadr.
   
    1.3) PostgreSQL, hangi Unix platforlarnda alr?
    
   Genel olarak, modern bir Unix-uyumlu platform PostgreSQL'i
   altracaktr. Ayrntl bilgi iin kurulum belgelerine
   bakabilirsiniz.
   
    1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
    
   PostgreSQL 8.0 srm ile , PostgreSQL artk Win2000, WinXP ve Win2003
   gibi Microsoft Windows NT tabanl iletim sistemlerinde doal olarak
   almaya balamtr. Paketlenmi bir kurulum program,
   http://pgfoundry.org/projects/pginstaller. adresinden indirilebilir.
   
   Ayrca, http://forge.novell.com adresinde Novell Netware 6 portu
   bulunmaktadr.
   
    1.5) PostgreSQL'i nereden indirebilirim?
    
   PostgreSQL iin ana anonim ftp sitesi ftp://ftp.PostgreSQL.org/pub
   adresidir. Yanslar iin, ana web sayfamza bakabilirsiniz.
   
    1.6) Nereden destek alabilirim?
    
   Ana e-posta listesi : pgsql-general@@PostgreSQL.org. PostgreSQL
   konusundaki tartmalara aktr. ye olmak iin, aadaki satrlar
   e-postanzn body ksmna (konu ksmna deil) yazp,
   pgsql-general-request@@PostgreSQL.org adresine gnderin:
subscribe
end

   Ayn zamanda, bir digest listesi bulunmaktadr. Bu listeye ye olmak
   iin, pgsql-general-digest-request@@PostgreSQL.org adresine, body
   ksmnda
subscribe
end

   yazan bir e-posta atmanz yeterli olacaktr.
   
   Digest postalar, ana liste 30k civarnda e-postaya ulatnda yelere
   gnderilmektedir.
   
   Bug'lar iin bir e-posta listesi bulunmaktadr. Bu listeye ye olmak
   iin, pgsql-bugs-request@@PostgreSQL.org adresine, body ksmnda
subscribe
end

   yazan bir e-posta atmanz yeterli olacaktr.
   
   Ayn zamanda, gelitiriciler iin tartma listesi bulunmaktadr. Bu
   listeye ye olmak iin, pgsql-hackers-request@@PostgreSQL.org adresine,
   body ksmnda
subscribe
end

   yazan bir e-posta atmanz yeterli olacaktr.
   
   Bunun dndaki e-posta listelerine ve PostgreSQL hakknda bilgiye,
   PostgreSQL WWW ana sayfasndan ulasabilirsiniz:
   http://www.PostgreSQL.org
   
   Ayn zamanda, EFNet zerinde, #PostgreSQL adl bir IRC kanal
   bulunmaktadr. Bunun iin, irc -c '#PostgreSQL' "$USER"
   irc.phoenix.net Unix komutunu kullanabilirsiniz.
   
   Ticari destek veren firmalarn listesine
   
   http://www.postgresql.org/users-lounge/commercial-support.html
   
   adresinden ulabilirsiniz.
   
    1.7) En son srm nedir?
    
   PostgreSQL'in son srm 7.4.6'dr.
   
   Her 6-8 ayda ana srm karlmas planlanmaktadr.
   
    1.8) Hangi belgelere ulaabilirim?
    
   Datmn iinde, kitapklar, kitapk sayfalar ve baz kk
   rnekler verilmektedir. /doc dizinine baknz. Ayrca, bu el
   kitapklarn online olarak http://www.PostgreSQL.org/docs/
   adresinden inceleyebilirsiniz.
   
   http://www.PostgreSQL.org/docs/awbook.html ve
   http://www.commandprompt.com/ppbook adreslerinde PostgreSQL kitaplar
   bulunmaktadr. PostgreSQL kitablarnn listesine,
   http://www.ca.PostgreSQL.org/books/ adresinden ulaaiblirsiniz.
   Ayrca, PostgreSQL konusundaki teknik makalelere de
   http://techdocs.PostgreSQL.org/ adresinden ulaabilirsiniz.
   
   psql'in, \d ile baslayan veri tipler, operatorler, fonksiyonlar,
   aggregate'ler, vb. ile ilgili gzel komutlar vardr.
   
   Web sitemiz daha fazla belgeyi iermektedir.
   
    1.9) Bilinen hatalar ya da eksik zelliklere nereden ulaabilirim?
    
   PostgreSQL SQL-92 uyumluluu iindedir, standartlardan fazla da
   zellikleri bulunmaktadr. Bilinen hatalar, eksik zellikler ve
   gelecek ile ilgili planlar iin TODO listesine baknz.
   
    1.10) Nasl SQL renebilirim?
    
   http:/www.PostgreSQL.org/docs/awbook.html adresindeki kitap SQL
   gretecektir. http://www.commandprompt.com/ppbook adresinde de bir
   baska PostgreSQL kitab bulunmaktadr.
   
   http://www.intermedia.net/support/sql/sqltut.shtm,
   http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM
   http://sqlcourse.com ve http://sqlcourse2.com adreslerinde de gzel
   belgeler bulunmaktadr.
   
   Bir bakas da, http://members.tripod.com/er4ebus/sql/index.htm
   adresinde bulunan "Teach Yourself SQL in 21 Days, Second Edition"
   kitabdr.
   
   Baz kullanclarmz da u kitab nermektedirler: "The Practical SQL
   Handbook, Bowman, Judith S., et al.,Addison-Wesley". Bazlar ise "The
   Complete Reference SQL, Groff et al., McGraw-Hill" kitabn
   nermektedirler.
   
    1.11) PostgreSQL 2000 ylna uyumlu mudur?
    
   Evet.
   
    1.12) Gelitirme takmna nasl katlabilirim?
    
   ncelikle, en son kaynak kodunu indirin ve web sitemizdeki ya da
   datmn iindeki PostgreSQL Developer belgesini okuyun. Ardndan,
   pgsql-hackers ve pgsql-patches listelerine ye olun. nc olarak da,
   pgsql-pacthes listesine yksek kalitede yamalar gnderin.
   
   PostgreSQL CVS arivine eriim izni olan, 10 kadar gelitirici
   bulunmaktadr. Hepsi defalarca, dier kiilerin yaptndan ok daha
   yksek-kaliteli yamalar gndermilerdir. Ayrca biz de bu
   gelitiricilerin ekledikleri yamalarn yksek kalitede olduuna
   gveniyoruz.
   
    1.13) Bir hata raporunu nasl gnderebilirim?
    
   PostgreSQL BugTool sayfasna gidiniz. O sayfada bir bug bildirmek iin
   neleri yapmanz gerektii anlatlmtr.
   
   Ayrca, ftp://ftp.PostgreSQL.org/pub ftp adresimizde, yeni bir
   PostgreSQL srm ya da yamas olup olmadni kontrol ediniz.
   
    1.14) PostgreSQL, diger DBMS'lerle nasl karlastrlabilir?
    
   Bir yazlmn gcn lmek iin eitli yollar vardr: Yazlmn
   zellikleri, baarm, gvenilirlii, destei ve creti.
   
   zellikler:
   
   PostgreSQL mevcut byk ticari veritabanlarnn, transaction,
   subselect, trigger, view, foreign key referential integrity ve
   sophisticated locking gibi (user-defined types), rules, inheritance ve
   lock cakmalarn drmek iin multi-version uyumluluk zellikleri
   bulunmaktadr.
   
   Performans (Baarm):
   
   PostgreSQL, dier ticari ve ak kaynak kodlu veritabanlaryla yakn
   baarm salar. Baz alardan daha hzldr, dier alardan da
   yavatr. MySQL ya da daha zayf veritabanlar ile
   karlatrldnda, INSERT/UPDATE ilemlerinde, transaction bazl
   alstmz iin daha yavaz. MySQL, yukardaki "zellikler"
   ksmnda belirtilenlerden hi birine sahip deildir. Biz, baarmmz
   her srmde arttrsak da, esneklik ve gelimi zellikler iin
   yaplanm durumdayz. PostgreSQL'i MySQL ile karlatran u web
   sitesine bakabilirsiniz: http://openacs.org/why-not-mysql.html
   
   Gvenilirlik:
   
   DBMS'lerin gvenilir olmas gerketii, yoksa deerleri olmayacan
   dnyoruz. ok iyi test edilmi, dengeli alsan minimum sayda hata
   ieren kod sunmaya alyoruz. Her bir srm en az 1 aylk beta
   testlerinden geirilmektedir. Srm gemiine bakarsanz, retime
   hazr, dengeli ve kararl kodlar sunduumuzu grebilirsiniz. Bu
   alanda, dier veritaban yazlmlarna stnlmz olduuna
   inanmaktayz.
   
   Destek:
   
   E-posta listemiz, oluan herhangi bir sorunu zebilecek byk sayda
   kullanc ve gelitirici grubunu ierir. Sorununuz iin, en az bir
   ticari veritaban kadar rahat zm bulabilirsiniz. Gelistiricilere,
   kullanc grubuna, belgelere ve kaynak koda direk olarak eriebilme,
   PostgreSQL desteini, dier DBMS'lere gre daha nemli klar.
   Gereksinimi olanlara, ticari destek verilebilir. (Destek iin 1.6
   blmne baknz.)
   
   Fiyat:
   
   Ticari ve ticari olmayan tm kullanmlarnz iin PostgreSQL
   cretsizdir. Kodumuzu, yukarda belirtilen BSD-stili lisanstaki
   snrlamalar hari, rnnzn iine ekleyebilirsiniz.
   
    1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
    
   PostgreSQL, 1996 ylndan beri 1. snf altyapya sahiptir. Bunun
   iin, yllar boyu alp bu altyapy oluturup yneten Marc
   Fournier'e teekkrler.
   
   Bir ak kaynak kodlu proje iin, kaliteli altyap ok nemlidir. Bu
   altyap, projenin kesilmesini nler ve projenin ilerlemesini
   hzlandrr.
   
   Tabii ki bu altyap ucuz deildir. lerin yrmesi iin eitli ylk
   ve anlk harcamalarmz olmaktadr. Eer siz ya da irketinizin bu
   abamza bata bulunabilecek paras varsa, ltfen
   http://store.pgsql.com/ adresine gidiniz ve bata, hibede bulununuz.
   
   Web sayfasnn 'PostgreSQL Inc.' den bahsetmesine ramen, "katkda
   bulunanlar" (contributors) maddesi sadece PostgreSQL projesini
   desteklemek iindir ve belirli bir irketin para kayna deildir.
   isterseniz, balant adresine bir ek gnderebilirsiniz.
     _________________________________________________________________
   
                         Kullanc/stemci Sorular
                                      
    2.1) PostgreSQL icin ODBC srcleri var m?
    
   iki tane ODBC srcs bulunmaktadr: PsqlODBC ve OpenLink ODBC.
   
   PsqlODBC'i
   http://gborg.postgresql.org/project/psqlodbc/projdisplay.php
   adresinden indirebilirsiniz.
   
   OpenLink ODBC http://www.openlinksw.com adresinden alnabilir.Bu
   src, kendi standart ODBC istemci yazlm ile alstndan,
   destekledikleri her platformda (Win, Mac, Unix, VMS) PostgreSQL ODBC
   bulunmalidir.
   
   cretsiz srm olmakla beraber, ticari kalitede destek almak
   isteyenlere satmak isteyeceklerdir. Sorularnz ltfen
   postgres95@@openlink.co.uk adresine gnderiniz.
   
    2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar
    bulunmaktadr?
    
   http://www.webreview.com/ adresinde, arka planda veritaban alstran
   Web sayfalar iin giri seviyesinde bilgi bulunmaktadr.
   
   Web ile btnleme iin, PHP () mkemmel bir arabirim sunar.
   
   Karmak sorunlar iin, ou kisi Perl arabirimini ve CGI.pm ya da
   mod_perl kullanr.
   
    2.3) PostgreSQL'in grafik kullanc arabirimi var mdr?
    
   eitli grafik arabirimlerimiz bulunmaktadr. Bunlarn arasnda,
   PgAccess (http://www.pgaccess.org/), PgAdmin II
   (http://www.pgadmin.org/, sadece Win32 iin), RHDB Admin
   (http://sources.redhat.com/rhdb/) ve Rekall
   (http://www.thekompany.com/products/rekall/) bulunmaktadr. Ayrca,
   PostgreSQL iin web tabanl bir arabirim olan PHPPgAdmin
   (http://phppgadmin.sourceforge.net/) bulunmaktadr.
   
   Daha ayrntl liste iin
   http://techdocs.postgresql.org/guides/GUITools adresine
   bakabilirsiniz.
   
    2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri kullanabilirim?
    
     * C (libpq)
     * Embedded C (ecpg)
     * Java (jdbc)
     * Python (PyGreSQL)
     * TCL (libpgtcl)
       
   Dierleri iin, http://gborg.postgresql.org adresindeki
   Drivers/Interfaces blmne bakabilirsiniz.
     _________________________________________________________________
   
                             Ynetimsel Sorular
                                      
    3.1) PostgreSQL'i, /usr/local/pgsql dizininden baka dizinlere nasl
    kurabilirim?
    
   configure betiini alstrrken, --prefix seeneini veriniz.
   
    3.2) postmaster'i baslattgmda, a Bad System Call ya da core dumped mesaj
    alyorum. Neden?
    
   Bunun birok nedeni olabilir. Ancak ilk kontrol edilmesi gereken sey,
   ekirdeginize System V uzantlarnn kurulu olup olmadgn kontrol
   etmek olabilir. PostgreSQL shared memory ve semaphores iin ekirdek
   destegine gereksinim duyar.
   
    3.3) postmaster'i balattmda, pcMemoryCreate hatas alyorum. Neden?
    
   Ya ekirdeinizde shared memory desteiniz dzgnce
   yaplandrlmamtr, ya da ekirdeinizdeki mevcut shared memory
   miktarn bytmeniz gerekecektir. Gereksinim duyacanz miktar,
   mimarinize ve postmaster iin ayarladgnz tampon ile backend ilemi
   saysna baldr. Tm sistemler iin, tamponlar ve ilemlerde
   ntanml saylarla, ~ 1MB kadar yere gereksinmeniz olacaktr.
   PostgreSQL 7.3.2 Sistem Yneticileri Rehberi'ne, shared memory ve
   semaphorelar hakkndaki ayrntl bilgi iin bakabilirsiniz.
   
    3.4) postmaster' balattmda, pcSemaphoreCreate hatas alyorum. Neden?
    
   Eer hata, "pcSemaphoreCreate: semget failed (No space left on
   device)" ise, ekirdeiniz yeterli semaphore ile yaplandrlmam
   demektir. Postgres, her bir potansiyel backend iin bir semaphore
   gereksinimi duyar. Geici bir zm, postmaster backend ilemleri
   iin daha az miktarda snrla balatmak olabilir. -N'i varsaylan
   deer olan 32'den kk bir deerle balatnz. Daha kalc bir zm,
   ekirdeinizin SEMMNS ve SEMMNI parametrelerini ykseltmek olacaktr.
   
   almayan semaphore'lar ar veritaban ilemlerinde kme
   yaratabilirler.
   
   Eer hata mesajnz baka bir ey ise, ekirdeinizde semaphore
   desteini yaplandrmam olabilirsiniz. Shared memory ve
   semaphore'lar hakkndaki daha ayrntl bilgi iin PostgreSQL 7.3.2
   Sistem Yneticileri Rehberi'ne bakabilirsiniz.
   
    3.5) Diger bilgisayarlarn benim PostgreSQL veritaban sunucuma
    balantlarn nasl kontrol edebilirim?
    
   n tanml olarak, PostgreSQL sadece yerel makineden Unix domain
   sockets kullanarak balanlmasna izin verir. Diger makineler,
   postmaster'a -i etiketini geirmezseniz ve $PGDATA/pg_hba.conf
   dosyasn dzenleyerek host-based authentication'a olanak vermezseniz,
   balant yapamayacaklardr.
   
    3.6) Veritabani motorunu daha iyi baarm iin nasl ayarlayabilirim?
    
   Index'ler sorgular hzlandrabilir. EXPLAIN komutu, PostgreSQL'in
   sorgunuzu nasl yorumladn ve hangi index'leri kullandn
   grmenize izin verir.
   
   Eer cok fazla INSERT ilemi yapyorsanz, bunlar byk bir toplu
   ilem dosyaskullanp COPY komutu ile veritabanna girmeyi deneyiniz.
   Bu, tekil INSERT'lerden daha hzldr. kinci olarak, BEGIN
   WORK/COMMIT transaction blou iinde olmayan ifadeler kendi
   transaction'larndaym gibi dnlr. oklu ifadeleri tek bir
   transaction blou iinde yapabilirsiniz. Bu, transaction overhead'ini
   drecektir. Tek bir transaction blou iinde birden ok ifadeyi
   altrmay deneyebilirsiniz. Bu da ayn ekilde, transaction
   overhead'ini drr.
   
   eitli ayarlama seenekleri mevcuttur. fsync() ilemini, postmaster'
   -o -F seenei ile balatarak devre d brakabilirsiniz. Bu ilem,
   fsync()'lerin her transactiondan sonra diski flush etmesini
   engelleyecektir.
   
   Ayn zamanda, postmaster'i -B seenei ile balatp, backend ilemleri
   tarafndan kullanlan shared memory buffers saylarn
   arttrabilirsiniz. Eer bu parametreyi ok yksek tutarsanz,
   ekirdeinizin shared memory blgesindeki limiti ama olaslnz
   yznden postmaster balayamayabilir. Her bir tampon (buffer) 8K'dr.
   ntanml say ise 64 tampondur.
   
   Ayn ekilde, backend'in -S seeneini geici sralamalar iin backend
   sreleri tarafndan kullanlacak hafzay arttrmak amacyla
   kullanabilirsiniz. -S seenei kilobayt cinsinden deer alr ve n
   tanml deeri 512'dir (512 K)
   
   Tablolardaki veriyi bir index'e elemek amacyla gruplama iin CLUSTER
   komutunu kullanabilirsiniz. Ayrntl bilgi iin CLUSTER komutunun
   yardm sayfasna bakabilirsiniz.
   
    3.7) Hangi hata ayklama zellikleri bulunmaktadr?
    
   PostgreSQL, hata ayklama amacyla kullanlabilecek durum bilgisi
   rapor eden eitli zeliklere sahiptir.
   
   ncelikle, configure betiini --enable-cassert seeneiyle
   altrrsanz, bir ok assert() backend calmasn gzlemler ve
   beklenmeyen bir durumda program durdurur.
   
   Postmaster ve postgres eitli hata ayklama seeneklerine sahiptir.
   ncelikle, postmaster' balattnzda, standart kty ve hatalar
   bir log dosyasna ynlendirdiinize emin olun:
cd /usr/local/pgsql
./bin/postmaster >server.log 2>&1 &

   Bu ilem PostgreSQL ana dizinine server.log dosyas yerletirecektir.
   Bu dosya sunucunun yaad sorunlar ya da hatalar hakknda yararl
   bilgiler ierir. -d seenei, hata ayklama seviyesini belirten bir
   rakam ile kullanlr. Yksek hata ayklama seviyelerinin byk log
   dosyalar oluturacan unutmaynz.
   
   Eer postmaster almyorsa, postgres backend'ini komut satrndan
   altrabilir ve SQL ifadenizi direk olarak yazabilirsiniz. Bu sadece
   hata ayklama amacyla nerilir. Burada, noktal virgln deil de
   yeni bir satrn sorguyu sonlandrdn unutmaynz. Eer hata
   ayklama sembolleri ile derlediyseniz, ne olduunu grmek iin bir
   hata ayklayc kullanabilirsiniz. backend postmaster'dan
   balatlmadndan, edeer bir ortamda almamaktadr ve
   locking/backend etkileim sorunlar artabilir.
   
   Eer postmaster alyorsa, bir pencerede psql'i altrn ve psql
   tarafndan kullanlan postgres srecinin sre numarasn (PID) bulun.
   Postgres sreci ile ilikilendirmek iin bir hata ayklarc kullann.
   Sorgular psql aracl ile altrabilirsiniz. Eer postgres
   balangcnda hata ayklamak istiyorsanz, PGOPTIONS="-W n" seeneini
   ayarlayabilir ve psql'i balatabilirsiniz. Bu ilem, balangcn n
   saniye kadar gecikmesini salayacaktr; bylece hata ayklaycy
   srece ilikilendirdikten sonra balang srecinin devam etmesini
   salayabilirsiniz.
   
   postgres program hata ayklama ve baarm lmleri iin -s, -A ve -t
   seeneklerine sahiptir.
   
    3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn
    alyorum?
    
   Postmaster'n ezamanl olarak balatabilecei backend sreleri
   snrlarn arttrmanz gerekmektedir.
   
   n tanml deer 32 sretir. Bunu, postmaster' uygun -N deeri ile
   ya da postgresql.conf dosyasn dzenleyerek yeniden balatmakla
   arttrabilirsiniz.
   
   Eer -N deerini 32'den byk yapacaksanz, ayn zamanda -B deerini
   de deitirmeniz gerektiini unutmayn. -B, -N'nin en az 2 kat kadar
   olmaldr; daha iyi baarm iin bu sayy daha da arttrmalsnz.
   Yksek saydaki backend sreleri iin, eitli ekirdek yaplandrma
   parametrelerini arttrmanz gerekecektir. Yaplmas gerekenler,
   SHMMAX, SEMMNS, SEMMNI, NPROC, MAXUPRC ve alabilecek dosyalarn
   maksimum says olan NFILE ve NINODE deerlerini kartrmaktr. Bunun
   nedeni, PostgreSQL'in izin verilen backend srelerinin says
   zerinde bir snr olmasdr. Bylelikle sistem kaynaklarnn dna
   klmayacaktr.
   
   PostgreSQL'in 6.5 srmne kadar, en fazla backend says 64 idi ve
   bunu deitirmek iin include/storage/sinvaladt.h dosyas iindeki
   MaxBAckendid sabitini deitirdek sonra yazlm yeniden derlemek
   gerekiyordu.
   
    3.9) pgsql_tmp dizinin iindeki dosyalar nelerdir?
    
   Sorgu alstrc (query executer) tarafndan yaratlan geici
   dosyalardr. rnegin, bir sralama ORDER BY ile yaplacaksa ve
   sralama backend'in -s parametresinin izin verdiinden daha fazla
   alana gereksinim duyuyorsa, ekstra veriyi tutmak iin geici dosyalar
   yaratlr.
   
   Geici dosyalar, eer sralama srasnda backend gmezse otomatik
   olarak silinecektir. Eer alan durumda bir backend'iniz yoksa,
   pg_tempNNN.NN dosyalarn silmeniz gvenlidir.
   
    3.10) PostgreSQL srmlerini ykseltmek iin neden bir dump/reload ilemi
    gerekletirmek zorundaym?
    
   PostgreSQL takm ara srmlerde sadece kk deiiklikler
   yapmaktadr; bu yzden 7.2 srmnden 7.2.1'e ykseltmek dump/restore
   ilemi gerekmemektedir. Ancak, esas srmlerde (rnek: 7.2'den 7.3'e)
   ounlukla sistem tablolarnn ve veri dosyalarnn i yaps
   deitirilir. Bu deiiklikler ounlukla karmaktr; dolaysyla
   veri dosyalarnn geriye dnk uyumluluu ilemlerini yapmyoruz. Dump
   ilemi, veriyi genel biimde alacandan yeniden ykleme esnasnda
   veri, yeni i biime uygun ekilde yerletirilecektir.
   
   Disk biiminin deimedii srmlerde, pg_upgrade betii gncellemenin
   bir dump/restore gerektirmeden yaplmasn salayacaktr. pg_upgrade
   betiinin o srm iin bulunup bulunmadn srm notlar iinde
   bulabilirsiniz.
   
    3.11) Nasl bir donanm kullanmalym?
    
   PC donanm tamamen uyumlu olduu iin, insanlar tm PC donanmlarnn
   ayn kalitede olduunu dnrler. Oysa byle deildir. ECC RAM, SCSI
   ve kaliteli anakartlar daha ucuz donanmlara gre daha ok
   gvenilirlerdir ve baarmlar daha yksektir. PostgreSQL hemen hemen
   tm donanmda alabilmektedir, ancak gvenilirlik ve baarm nemli
   ise donanm seeneklerini ok iyi aratrmak gereklidir. E-posta
   listelerimi donanmlarla ilgili sorular ve de ticaret iin
   kullanlabilir.
     _________________________________________________________________
   
                             letimsel Sorular
                                      
    4.1) Binary cursor ve normal cursor arasndaki fark nedir?
    
   DECLARE yardm sayfasna baknz.
   
    4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
    
   FETCH yardm sayfasna baknz, ya da SELECT ... LIMIT ... kullannz.
   
   lk birka satr almak isteseniz bile, tm sorgu deerlendirilmek
   durumunda kalnabilir. ORDER BY ieren bir sorgu dnn. Eer ORDER
   BY ie eleen bir index varsa, PostgreSQL istenen ilk birka satr
   ileyebilir, ya da tm sorgu istenen satrlar retilene kadar
   ilenebilir.
   
    4.3) psql'in iinde grdgm tablolarn ya da dier eylerin listesini
    nasl alabilirim?
    
   pgsql/src/bin/psql/describe.c iindeki psql kaynak kodunu
   okuyabilirsiniz. Bu kod, psql'in \ ile balayan komutlarnn ktsn
   olusturan SQL komutlarn ierir. Ayn zamanda, psql'i -E seenei ile
   balatp, verdiiniz komutlar altrmak iin yapt sorgularn
   ktlarn grebilirsiniz.
   
    4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
    
   Bu zellik (ALTER TABLE DROP COLUMN) 7.3 srm ile gelmitir. Eski
   srmlerde aadakileri uygulamalsnz:
BEGIN;
LOCK TABLE old_table;
SELECT ...  -- select all columns but the one you want to remove
INTO TABLE new_table
FROM old_table;
DROP TABLE old_table;
ALTER TABLE new_table RENAME TO old_table;
COMMIT;
                
    4.5) Bir satr, tablo ve veritaban iin en fazla byklk nedir?
    
   Snrlar:
   
   Veritaban iin en fazla byklk nedir?
   Snrsz (32 TB'lk veritaban bulunmaktadr)
   Bir tablo iin en fazla byklk nedir?
   32 TB
   Bir satr iin en fazla byklk nedir?
   1.6 TB
   Bir alan iin en fazla byklk nedir?
   1 GB
   Tabloda en fazla satr says katr?
   Snrsz
   Bir tabloda olabilecek en fazla kolon says katr?
   Kolon tiplerine bal olarak 250-1600
   Bir tabloda olabilecek en fazla index says katr?
   Snrsz
   
   Tabii ki bunlar aslnda snrsz degildir. Burada belirtilen snrlar,
   fiziksel snrlarn haricindeki snrlardr. Bo disk alan,
   hafza/takas alan na bal snrlamalar vardr. Baarm, snr
   deerlere yaklatka, ya da deerler ok byk olduunda debilir.
   
   Bir tablo iin byklk snr olan 32 TB, iletim sisteminin byk
   dosya destei olup olmamasndan bamszdr. Byk tablolar, 1 GB'lik
   dosyalarda sakland iin, dosya sistemi snrlarnin bir nemi
   yoktur.
   
   Tablo ve kolon says byklkleri, n tanml blok bykl 32k ya
   karlarak arttrlabilir.
   
    4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk alan
    gereklidir?
    
   Bir PostgreSQL veritaban, veriyi "flat" metin dosyasnda saklamak
   iin gereken alann 5 kat fazla disk alanna gereksinim duyabilir.
   
   Her satrnda bir tamsay ve metin (text) ieren, 100.000 satrlk bir
   dosya dnn. Her satrn ortalama 20 byte olduunu farzedelim. Metin
   dosyas 2.8 MB olacaktr. Bu veriyi tutan PostgreSQL veritaban
   yaklak 6.4 MB yer kaplayacaktr.
  36 byte: Her bir satr bal (yaklak)
+ 24 byte: Bir tamsay (int) alan ve bir metin (text) alan
+  4 byte: Sayfada tuple a pointer
----------------------------------------
  64 byte -> kayt bana

   PostgreSQL'de veri sayfas (data page) bykl 8192 byte (8k)dr,
   dolaysyla:
8192 byte -> page bana
-------------------------  =  Her bir veritaban page' bana 128 satr (yaklak)
  Satr bana 64 byte

100000 veri satr
--------------------  =  782 veritaban sayfas
     128 satr

   782 veritaban sayfas * sayfa bana 8192 byte = 6,406,144 bytes (6.4
   MB)
   
   Index'ler ok fazla yere gereksinim duymazlar, ama index'lenmi veriyi
   tutacaklarndan byk olabilirler.
   
   NULL deerler bitmapler iinde tutulur; dolaysyla ok az yer
   kaplarlar.
   
    4.7) Veritabannda hangi tablo ya da index'lerin tanmlandn nasl
    grebilirim?
    
   psql, bu tr bilgileri gstermek iin, \ ile balayan bir ok komut
   sunmaktadr. \? komutu ile bu komutlar grebilirsiniz. Ayrca,
   bunlar aklayan ve pg_ ile balayan ok sayda sistem tablosu
   bulunmaktadr. Ayn zamanda, psql -l ile tm veritabanlarn
   listeyelebirsiniz.
   
   Ayrca, pgsql/src/tutorial/syscat.source kodunu inceleyebilirsiniz. Bu
   dosya, veritaban sistem dosyalarndan bilgiyi almak iin gereksinim
   duyulan bir ok SELECT'leri gsterir.
   
    4.8) Sorgularm cok yava, ya da index'lerimi kullanmyorlar. Neden?
    
   Indexler her sorgu tarafndan otomatik olarak kullanlmazlar. Indexler
   eer bir tablonun bykl minimum bir byklkten fazla ise ve sorgu
   tablodaki satrlarn sadece kk bir yzdesini seiyorsa kullanlr.
   Bunun nedeni, index eriiminin neden olduu raslansal disk eriimi nin
   diskin ya da tablonun sral okunmasndan daha yavas olabilmesidir.
   
   Bir index'in kullanlp kullanlmayacan belirlemek iin, PostgreSQL
   tablo hakkndaki istatistiklere gereksinmesi vardr. Bu istatistikler,
   VACUUM ANALYZE kullanlarak toplanrlar. Optimizer, istatistikleri
   kullanarak, tabloda ka satr olduunu ve bilir ve indexin kullanlp
   kullanlmayacana daha iyi karar verir. Istatistikler, ayn zamanda
   en uygun join srasn ve yntemini belirlemekte ok nemlidir.
   statistik toplanmas, tablo ierikleri deitike periyodik olarak
   yaplmaldr.
   
   Indexler normalde ORDER BY sorgular ya da join ilemlerini
   gerekletirmek iin kullanlmazlar. Ak bir sralamay takip eden
   sral bir arama (sequential scan), byk bir tabloda index aramas
   yapmaktan genelde daha hzldr.
   Ancak, ORDER BY ile birlemi LIMIT genellikle bir index
   kullanacaktr; nk tablonun sadece belirli bir miktar
   dndrlecektir. Aslnda, MAX() ve MIN() fonksiyonlarnn index
   kullanmamalarndan dolay, bu gibi deerleri ORDER BY ve LIMIT
   kullanarak da almak olasdr:
    SELECT col
    FROM tab
    ORDER BY col [ DESC ]
    LIMIT 1;

   Eer optimizer'n sral arama yapmasnn yanl olduuna
   inanyorsanz, SET enable_seqscan TO 'off' kullann ve index kullanan
   aramalarn hala daha hzl olup olmadn grn.
   
   LIKE ya da ~ gibi operatrler kullanyorsanz, index'ler sadece
   aadaki koullarda kullanlabilir:
     * Arama dizininin ba, dizinin ba ile balanmaldr. Yani,
          + LIKE sorgular % ile balamamaldr.
          + Dzenli ifade sorgular ^ ie balamamaldr.
     * Arama metni bir karakter snf ile balayamaz. rnek: [a-e]
     * ILIKE ve ~* gibi byk/kk harfe duyarsz aramalar index'lerden
       yararlanmazlar. Onun yerine, blm 4.12'de anlatlan fonksiyonel
       index'leri kullanabilirsiniz.
     * initdb srasnda ntanml C locale'i kullanlmaldr.
       
    4.9) query-optimizer'n sorgularm nasl deerlendirdiini, ileme
    soktuunu nasl grebilirim?
    
   EXPLAIN yardm sayfasna baknz.
   
    4.10) R-tree index nedir?
    
   R-tree index, uzaysal (spatial) verileri indexlemek iin kullanlr.
   Bir hash index, dizi aramalarnda (range search) kullanlamaz. B-tree
   index dizi aramalarnda sadece tek boyutlu almaktadr. R-tree, ok
   boyutlu veriyi destekler. rnein, eer bir R-tree index point veri
   tipi zerinde ina edililebilirse, sistem "select all points within a
   bounding rectangle" gibi sorgulara daha verimli yantlar verecektir.
   
   Orijinal R-tree tasarmn aklayan belge:
   
   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.
   
   Bu belgeyi, Stonebraker'n "Readings in Database Systems" kitabnda
   bulabilirsiniz.
   
   Gml R-tree indexleri poligon ve boxlar kullanabilir. Teorik
   olarak, R-tree indexlerin zelliklerini geniletmek bir miktar aba
   gerektirir ve bunun nasl yaplacana dair bir belgemiz henz
   bulunmamaktadr.
   
    4.11) Genetic Query Optimizer nedir?
    
   GEQO modl, Genetic Algorithm(GA) kullanlarak tablolar
   birletirildiinde sorgu optimizasyonunu hzlandrr.
   
    4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe
    duyarsz aramalar nasl yapabilirim? Bu byk(kk harfe duyarl aramalar
    iin index'i nasl kullanabilirim?
    
   ~ operatr dzenli ifade elemesi ve ~* byk/kk harfe duyarsz
   dzenli ifade elemesi yapar. Byk/kk harfe duyarl olan LIKE'n
   byk/kk harfe duyarsz olan biimi ILIKE'tr ve PostgreSQL 7.1
   srm ile birlikte gelmitir.
   
   Byk-kk harfe duyarsz eitlik karlatrmalar aadaki gibi
   ifade edilir:
SELECT *
FROM tab
WHERE lower(col) = 'abc'
                
   Bu standart bir index yaratmayacaktr. Ancak eer fonksiyonel bir
   index yaratrsanz; o kullanlacaktr:
CREATE INDEX tabindex on tab (lower(col));

    4.13) Bir sorguda, bir alanin "NULL" olduunu nasl ortaya karabilirim?
    
   Kolonu, IS NULL ve IS NOT NULL ile test edebilirsiniz.
   
    4.14) esitli karakter tipleri arasndaki farklar nelerdir?
    
Veri Tipi            Ad              Not
--------------------------------------------------
VARCHAR(n)      varchar         boyut en byk uzunluu verir; sadece verilen kadar veri tutulur.
CHAR(n)         bpchar          belirtilen uzunlua kadar sonuna  boluk eklenir.
TEXT            text            uzunlukta herhangi bir st snr yoktur.
BYTEA           bytea           variable-length byte array (null-byte safe)
"char"          char            bir karakter
                
    adlar (internal name) sistem kataloglarn ve baz hata
   mesajlarn incelerken greceksiniz.
   
   lk drt veri tipi "varlena" tipidir (yani, diskteki ilk 4 bayt
   uzunluktur; devam da veridir.) Dolaysyla, kullanlan gerek alan,
   belirtilen alandan biraz daha byktr. Ancak, bu veri tipleri,
   sktrlmaya tabi tutulabilir; dolaysyla disk alan beklenilenden
   kk olabilir. VARCHAR(n) bykl artabilen ama en byk uzunluu
   snrl olan verileri saklamak iin en uygun yntemdir. TEXT, 1 GB
   bykle kadar olan verileri tutmak iin kullanlr.
   
   CHAR(n), ayn uzunluktaki dizilerin saklanmas iin kullanmr.
   CHAR(n) belirtilen uzunlua kadar boluk ile doldurur; ancak
   VARCHAR(n) sadece verilen karakterleri saklar. BYTEA binary veri
   saklamak iindir; ayrca "NULL" bayt ieren deerleri de saklar.
   Burada anlatlan  veri tipi de benzer baarm karakteristiklere
   sahiptir.
   
    4.15.1) Nasl serial/otomatik artan (auto-incrementing) bir alan
    yaratabilirim?
    
   PostgreSQL'de SERIAL veri tipi vardr. Bu veri tipi bir sequence ve
   kolon zerinde bir index yaratr.
   
   rnek, aadaki sorgu:
CREATE TABLE person (
    id   SERIAL,
    name TEXT
);
                
   buna evrilir:
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 );
                
   Sequenceler hakknda daha fazla bilgi iin create_sequence yardm
   sayfasna bakabilirsiniz. Her satrn OID alann tekil bir say
   olarak alabilirsiniz. Ancak, veritabannzn dump'n alp yeniden
   yklerseniz, OID deerlerini koruyabilmek iin pg_dump'n -o
   parametresini ya da "COPY WITH OIDS" seeneini kullanmanz
   gerekecektir.
   
    4.15.2) SERIAL giriinin degerini nasl alabilirim?
    
   Bir yaklam, sequence nesnesindeki SERIAL deerini, veriyi girmeden
   nce nextval() ile alp, aldnz deeri kendinizin girmesidir.
   4.15.1'deki rnek tabloyu kullanarak bir rnek verelim:
new_id = execute("SELECT nextval('person_id_seq')");

    execute("INSERT INTO person (id, name) VALUES (new_id, 'Blaise Pascal')");

   Dier sorgular iin new_id'de yeni deerin saklanmas gerekir.
   Otomatik olarak yaratlan SEQUENE nesnesinin ad, <tablo ad>_<serial
   kolonu ad>_seq eklinde olacaktr (< > iaretleri olmadan).
   
   Alternatif olarak, atanm SERIAL deerini, deer girildikten sonra
   currval() fonksiyonu ile alabilirsiniz:
                execute("INSERT INTO person (name) VALUES ('Blaise Pascal')");
                new_id = execute("SELECT currval('person_id_seq')");
                
   Son olarak, n tanml deeri bulmak iin INSERT ifadesinden dnen OID
   deerini kullanabilirsiniz; ancak bu en az tanabilir zm
   olacaktr. Perl'de, Edmund Mergl'in DBD:Pg mdl ile birlikte DBI
   kullanarak, OID deeri $sth->execute() altrldktan sonra
   $sth->(pg_oid_status) ile alnabilir.
   
    4.15.3) currval() ve nextval() dier kullanclara sorun yaratmaz m?
    
   Hayr. curval(), tm kullanclar deil, backend tarafndan atanan
   geerli deeri dndrr.
   
    4.15.4) Neden sequence saylar transaction ileminin iptalinden sonra
    yeniden kullanlyor? Neden sequence/SERIAL kolonumdaki saylarda atlamalar
    oluyor?
    
   Uyumluluu arttrmak iin, sequence deerleri alan transaction'lara
   gerektii ekilde aktarlr ve transaction bitene kadar o deer
   kilitlenmez. Bu, iptal edilen transaction ilemleri nedeniyle
   boluklara neden olur.
   
    4.16) OID nedir? TID nedir?
    
   OIDler, tekil satr numaralarna PostgreSQL'in yantdr.
   PostgreSQL'de yaratlan her say, tekil bir OID alr. initdb ilemi
   srasnda yaratlan tm OID'ler 16384'ten kktr
   (backend/access/transam.h). Kullanclar tarafndan yaratlan tm
   OID'ler bu sayya eit ya da bu saydan byktr. Varsaylan durumda,
   tm bu OIDler sadece bir tablo ya da veritabannda deil, tm
   PostgreSQL kurulumunda tekildir.
   
   PostgreSQL OIDleri, tablolar arasnda satrlar ilikilendirmek iin
   kendi i tablolarnda kullanr. Bu OIDler belirli kullanc
   satrlarn belirtmek iin kullanabilir ve join ilemlerinde
   kullanlr. OID deerlerini saklamak iin OID kolon tipini kullanmanz
   nerinir. Daha hzl bir eriim iin, OID alannda bir index
   yaratabilirsiniz.
   
   OID'ler yeni satrlara, tm veritabanlar tarafnda kullanlan ortak
   bir alandan atanrlar. Eer OID'i baka bir deere eitlemek
   isterseniz ya da tablonun bir kopyasn orijinal OIDler ile karmak
   isterseniz, bu mmkndr:
                        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';
                
   OIDler 4-bit tamsay olarak saklanrlar ve 4 milyarda overflow
   olacaktr. Kimse bu sayya ulatna dair bir bilgi iletmedi ve bu
   snr kimse bu snra ulamadan kaldracaz.
   
   TIDler, belirli fiziksel satrlar block ve offset deerleri ile
   belirtmekte kullanlr. TIDler, satrlar deitiinde ya da yeniden
   yklendiinde deiirler. Index girdileri tarafndan fiziksel
   satrlar gstermek iin kullanlrlar.
   
    4.17) PostgreSQL'de kullanlan baz terimlerin anlamlar nelerdir?
    
   Kaynak kodun bir ksm ve eski belgeler, daha geni kullanm alan
   olan terimleri kullanrlar. Bunlarn bazlar:
     * table, relation, class
     * row, record, tuple
     * column, field, attribute
     * retrieve, select
     * replace, update
     * append, insert
     * OID, serial value
     * portal, cursor
     * range variable, table name, table alias
       
   Genel veritaban terimleri,
   http://hea-www.harvard.edu/MST/simul/software/docs/pkgs/pgsql/glossary
   /glossary.html adresinde bulunabilir.
   
    4.18) Neden "ERROR: Memory exhausted in AllocSetAlloc()" hatasn alyorum?
    
   Sisteminizde sanal belleinizi tketmi olabilirsiniz, ya da
   ekirdeiniz belli kaynaklar icin dk bir snra sahip olabilir.
   postmaster' balatmadan nce aadakileri deneyebilirsiniz:
ulimit -d 262144
limit datasize 256m
                
   Kabuunuza bal olarak, bunlardan sadece biri olumlu sonu
   verecektir, ama bu ilem veri segment snrnz arttracak, ve belki
   de sorgunuzun tamamlanmasn salayacaktr. Bu komut, varolan ileme
   (current process) ve komut altrldktan sonraki tm alt ilemlere
   uygulanr. Eer SQL istemcinizle, backend'in ok fazla veri dndrmesi
   nedeniyle bir sorun yayorsanz, bunu istemciyi balatmadan nce
   deneyiniz.
   
    4.19) Hangi PostgreSQL srmn altrdm nasl grebilirim?
    
   psql arabiriminde, select version(); yaznz.
   
    4.20) Neden large-object ilemlerim, "invalid large obj descriptor"
    hatasn veriyor?
    
   Large object ilemlerinizin ularna, yani lo_open ... lo_close
   komutlarnn evresine, BEGIN WORK ve COMMIT koymanz gerekmektedir;
   
   u anda, PostgreSQL kurallar large objectleri transaction commit
   edildiinde kapatarak uygulamaktadr. Dolaysyla handle ile yaplacak
   ilk ey invalid large obj descriptor hatas ile
   sonulanacaktr.Dolaysyla alan kodunuz eer transaction
   kullanmazsanz hata mesajlar retecektir.
   
   Eer ODBC gibi bir istemci arabirimi kullanyorsanz, auto-commit'i
   kapatmanz gerekebilir.
   
    4.21) u andaki zaman ntanml deer olarak kabul eden How do I create a
    column that will default to the current time?
    
   Alttakini kullanabilirsiniz:
CURRENT_TIMESTAMP:
CREATE TABLE test (x int, modtime timestamp DEFAULT CURRENT_TIMESTAMP );
                
    4.22) Neden IN kullanan subquery'lerim ok yavas?
    
   7.4 srmnden nce, subqueryler. Eer subquery sadece birka satr ve
   outer query bol sayda satr dndryorsa, IN en hzlsdr. Sorgular
   hzlandrmak iin IN yerine EXISTS kullann:
SELECT *
    FROM tab
    WHERE col1 IN (SELECT col2 FROM TAB2)
                
   sorgusunu, aadaki ile deitirin:
SELECT *
    FROM tab
    WHERE EXISTS (SELECT col2 FROM TAB2 WHERE col1 = col2)
                
   Bu ilemin hzl olmas iin, subcol'un indexlenmi bir kolon olmas
   gerekmektedir.
   
   7.4 srm ve sonrasnda, IN aslnda normal sorgularla ayn karmak
   join tekniklerini kullanr ve EXISTS'e tercih edilir.
   
    4.23) Outer join ilemini nasl yapabilirim?
    
   PostgreSQL outer joins islemlerini SQL standartlarn kullanarak
   gerekletirmektedir. Aada 2 rnek bulunmaktadr:
SELECT *
FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);
                
   ya da
SELECT *
FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);
                
   Bu zde sorgular t1.col' i t2.col'ye join ederler ve ayn zamanda
   t1'deki unjoined satrlar (t2'de elenmemi olanlarla) dndrrler.
   RIGHT JOIN t2'nin unjoined satrlarn ekleyecektir. Bir FULL join,
   elemi btn satrlar ve t1 ile t2'den tm balanmam (unjoined)
   satrlar alr. OUTER szc seimseldir ve LEFT, RIGHT ve FULL join
   ilemlerinde olduu kabul edilir. Sradan join ilemleri INNER JOIN
   olarak adlandrlr.
   
   nceki srmlerde, OUTER JOINler UNION ve NOT IN kullanlarak simle
   edilebiliyordu. rnein, tab1 ve tab2'yi birletirirken, aadaki
   sorgu iki tablonun dtan balanmasn salar:
SELECT tab1.col1, tab2.col2
FROM tab1, tab2
WHERE tab1.col1 = tab2.col1
UNION ALL
SELECT tab1.col1, NULL
FROM tab1
WHERE tab1.col1 NOT IN (SELECT tab2.col1 FROM tab2)
ORDER BY col1
                
    4.24) Ayn andan birden fazla veritabannda nasl ilem yapabilirim?
    
   Mevcut veritabannz dndaki baka bir veritabannz sorgulamanzn
   bir yolu bulunmamaktadr. Bunun nedeni, PostgreSQL'in veritabanna
   zel sistem kataloglar yklemesidir. Bu nedenle, cross-database bir
   sorgunun nasl davranacan kestirmek zordur.
   
   contrib/dblink fonksiyon arlarn kullanarak cross-database
   sorgulara izin verir. Tabii ki, bir istemci deiik veritabanlarna
   ayn anda eriim salayabilir ve bilgiyi bu ekilde birletirebilir.
   
    4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?
    
   7.3 srmnde, bir fonksiyondan kolaylkla oklu satr ya da stun
   dndrebilirsiniz.
   (http://techdocs.postgresql.org/guides/SetReturningFunctions)
   
    4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo
    yaratma/kaldrma ilemlerini yapamyoruz?
    
   PL/PgSQL fonksiyon ierikleri cache'ler. Bunun istenmeyen bir taraf,
   eer bir PL/PgSQL fonksiyonu geici bir tabloya eriiyorsa ve bu tablo
   ileride kaldrlp yeniden oluturulduktan sonra fonksiyon yeniden
   arlrsa, fonksiyon almayacaktr; nk cache'lenmi fonksiyon
   hala eski geici tabloyu gsteriyor olacaktr. zm, geici tablo
   eriimleri iin PL/PgSQL'de EXECUTE kullanmaktr. Bu, sorgunun her
   seferinde yeniden ilenmesini salayacaktr.
   
    4.27) 4.28) Hangi ifreleme seenekleri bulunmaktadr?
    
     * contrib/pgcrypto SQL sorgularnda kullanlabilmesi iin ifreleme
       fonksiyonlar iermektedir.
     * stemciden sunucuya iletiimi ifrelemek iin, sunucuda ssl
       seenei postgresql.conf iinde ak olmaldr. Ayrca,pg_hba.conf
       dosyas iinde host ya da hostssl kayd mutlaka olmaldr ve
       istemci sslmode kapatlmamaldr. (Ayn zamanda,PostgreSQL'in
       doal SSL balantlar dnda ssh ya da ssl gibi 3.parti
       ifrelenmi veri iletimi de mmkndr.)
     * Veritaban kullanc ad ve ifreleri 7.3 srm ile birlikte
       otomatik olarak ifrelenirler. nceki srmlerde, postgresql.conf
       iindeki PASSWORD_ENCRYPTION seeneini aktif hale getirmeniz
       gerekmektedir.
     * Sunucunun kendisini ifreli dosya sistemi zerinde
       altrabilirsiniz.
     _________________________________________________________________
   
                    PostgreSQL zelliklerini Geniletmek
                                      
    5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman
    neden core dump ediyor?
    
   Sorunun nedeni birden fazla ey olabilir. Kullanc-tanml
   fonksiyonunuzu stand-alone bir programda altrmay deneyiniz.
   
    5.2) PostgreSQL'e nasl yeni tipler/fonksiyonlar ekleyebilirim?
    
   almalarnz pgsql-hackers e-posta listesine gnderiniz. Kodunuz
   incelendikten sonra contrib dizinine konacaktr.
   
    5.3) Bir tuple dondrmek icin bir C fonksiyonunu nasil yazarm?
    
   PostgreSQL 7.3 srm ile birlikte, C, PL/PgSQL ve SQL kullanlarak
   tablo-dndren fonksiyonlar tamamen desteklenmektedir. Ayrntl bilgi
   iin PostgreSQL 7.3.2 Kullanc Rehberi'ne bakabilrisiniz. Bir rnei
   contrib/tablefunc iinde bulabilirsiniz.
   
    5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen
    deiiklik geerli olmuyor. Neden?
    
   Makefile'lar include dosyalar iin tam bir bamllk iermezler.
   ncelikle make clean, ardndan da baska bir make ilemi yapmanz
   gerekir. GCC kullanyorsanz, configure betiinin --enable-depend
   seeneini, derleyicinin bamllklar otomatik olarak hesaplamas
   iin kullanabilirsiniz.
@


1.12
log
@Update copyright for 2009.
@
text
@@


1.12.2.1
log
@Remove translated FAQs

The English FAQ has been moved to the wiki, so the translated versions should
have been removed at that point as well.

The FAQ_MINGW.html should have been removed when the platform FAQs were
integrated into the documentation (or earlier).

applied to both 8.4 and 8.5
@
text
@@


1.11
log
@Change /contrib to contrib for consistency.
@
text
@d159 1
a159 1
   Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
@


1.10
log
@Update copyrights in source tree to 2008.
@
text
@d1176 1
a1176 1
   incelendikten sonra /contrib dizinine konacaktr.
@


1.9
log
@Update CVS HEAD for 2007 copyright.  Back branches are typically not
back-stamped for this.
@
text
@d159 1
a159 1
   Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
@


1.8
log
@Update copyright for 2006.  Update scripts.
@
text
@d159 1
a159 1
   Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group
@


1.8.2.1
log
@Backpatch FAQs to stable branch.
@
text
@d159 1
a159 1
   Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
@


1.7
log
@Here's the patch to fix a lot of markup errors in the HTML FAQs. Doesn't
change content (at least not supposed to).

Magnus Hagander
@
text
@d159 1
a159 1
   Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
@


1.7.2.1
log
@Update AIX FAQ to show readline options more clearly.

Backpatch FAQ's to 8.1.X.
@
text
@d159 1
a159 1
   Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group
@


1.6
log
@Update Turkish FAQ.

Devrim GUNDUZ
@
text
@a0 147
PostgreSQL iin Ska Sorulan Sorular (SSS)

Son gncelleme : 15 Kasm 2004 Pazartesi - 14:47:20

Current maintainer: Bruce Momjian (pgman@@candle.pha.pa.us)

evirenler : Devrim Gndz (devrim@@tdmsoft.com)
Nicolai Tufar (ntufar@@tdmsoft.com)
Volkan YAZICI (volkany@@phreaker.net)

Bu belgenin en gncel hali, http://www.PostgreSQL.org/docs/faqs/FAQ_turkish.html ve 
http://www.gunduz.org/seminer/pg/FAQ_turkish.html adreslerinde grlebilir.

Platforma zel sorularnz, http://www.PostgreSQL.org/docs/index.html adresinde yantlanr.
Genel Sorular
1.1) PostgreSQL nedir? Nasl okunur?
1.2) PostgreSQL'in haklar nedir?
1.3) PostgreSQL, hangi Unix platformlarnda alr?
1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
1.5) PostgreSQL'i nereden indirebilirim?
1.6) Destei nereden alabilirim?
1.7) En son srm nedir?
1.8) Hangi belgelere ulaabilirim?
1.9) Bilinen hatalar ya da eksik zelliklere nereden ulasabilirim?
1.10) Nasl SQL renebilirim?
1.11) PostgreSQL 2000 ylna uyumlu mudur?
1.12) Gelitirme takmna nasl katlabilirim??
1.13) Bir hata raporunu nasl gnderebilirim?
1.14) PostgreSQL, dier VTYS(DBMS) lerle nasl karlatrlabilir?
1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
Kullanc/istemci Sorular
2.1) PostgreSQL iin ODBC srcleri var m?
2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar bulunmaktadr?
2.3) PostgreSQL'in grafik kullanc arabirimi var mdr?
2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri kullanabilirim?
Ynetimsel Sorular
3.1) PostgreSQL'i /usr/local/pgsql dizininden baka dizinlere nasl kurabilirim?
3.2) Postmaster' balattmda Bad System Call ya da core dumped mesaj alyorum. Neden?
3.3) Postmaster' balattmda, IpcMemoryCreate hatas alyorum. Neden?
3.4) Postmaster', balattmda, IpcSemaphoreCreate hatas alyorum. Neden?
3.5) Dier bilgisayarlarn benim PostgreSQL veritaban sunucuma balantlarn nasl kontrol edebilirim?
3.6) Veritaban motorunu daha iyi baarm icin nasl ayarlayabilirim?
3.7) Hangi hata ayklama zellikleri bulunmaktadr?
3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn alyorum. Neden?
3.9) pgsql_tmpdizinin iindeki dosyalar nelerdir?
3.10) PostgreSQL srmlerini ykseltmek iin neden bir dump/reload ilemi gerekletirmek zorundaym?
3.11) Nasl bir donanm kullanmalym?br>
letimsel Sorular
4.1) Binary cursor ve normal cursor arasndaki fark nedr?
4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
4.3) psql'in iinde grdgm tablolarn ya da dier eylerin listesini nasl alabilirim?
4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
4.5) Bir satr, tablo ve veritaban iin en fazla byklk nedir?
4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk alan gereklidir?
4.7) Veritabannda hangi tablo ya da index'lerin tanmlandn nasl grebilirim?
4.8) Sorgularm cok yava, ya da index'lerimi kullanmyorlar. Neden?
4.9) Query-optimizer'n sorgularm nasl deerlendirdiini, ileme soktuunu nasl grebilirim?
4.10) R-tree index nedir?
4.11) Genetic Query Optimizer nedir?
4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasl yapabilirim? Bu 
byk/kk harfe duyarl aramalar iin index'i nasl kullanabilirim?
4.13) Bir sorguda, bir alann NULL olduunu nasl ortaya karabilirim?
4.14) esitli karakter tipleri arasndaki farklar nelerdir?
4.15.1) Nasl serial/otomatik artan (auto-incrementing) bir alan yaratabilirim?
4.15.2) Serial giriinin deerini nasl alabilirim?
4.15.3) currval() ve nextval() dier kullanclara sorun yaratmaz m?
4.15.4) Neden sequence saylarn transaction ileminin iptalinden sonra yeniden kullanlyor? Neden sequence/SERIAL 
kolonumdaki saylarda atlamalar oluyor?
4.16) OID nedir? TID nedir?
4.17) PostgreSQL' de kullanlan baz terimlerin anlamlar nelerdir?
4.18) Neden "ERROR: Memory exhausted in AllocSetAlloc()" hatasn alyorum?
4.19) Hangi PostgreSQL srmn alstrdm nasl grebilirim?
4.20) Neden large-object ilemlerim, "invalid large obj descriptor" hatasn veriyor?
4.21) u andaki zaman ntanml deer olarak kabul eden kolonu nasl yaratrm?
4.22) Neden IN kullanan subquery'lerim ok yava?
4.23) Outer join ilemini nasl yapabilirim?
4.24) Ayn anda birden fazla veritabannda nasl ilem yapabilirim?
4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?
4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?
4.27) Hangi ifreleme seenekleri bulunmaktadr?
PostgreSQL zelliklerini Geniletmek
5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman neden core dump ediyor?
5.2) PostgreSQL'e nasl yeni veri tipleri/fonksiyonlar ekleyebilirim?
5.3) Bir tuple dndrmek iin bir C fonksiyonunu nasl yazarm?
5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen deiiklik geerli olmuyor. Neden?
Genel Sorular
1.1) PostgreSQL nedir? Nasl okunur?

PostgreSQL, Post-Gres-Q-L. olarak okunur

PostgreSQL, yeni-nesil VTYS aratrma prototipi olan POSTGRES veritaban ynetim sisteminin gelitirilmesidir. 
POSTGRES'in zengin veri tiplerini ve gl veri modelini tutarken, SQL'in gelitirilmi alt kmesi olan PostQuel dilini 
kullanr. PostgreSQL cretsizdir ve kaynak kodu ak datlr.

PostgreSQL, PostgreSQL gelitirme listesine ye olan bir Internet gelitirici takm tarafndan gelitirilir. u andaki 
koordinatr, Marc G. Fournier (scrappy@@PostgreSQL.org). (Bu takma nasl katlacagnz renmek iin 1.6 numaral 
maddeyi okuyunuz.) Bu takm, tm PostgreSQL geliiminden sorumludur.

PostgreSQL 1.01 srmnn yazarlar Andrew Yu ve Jolly Chen idi. Bunlarn dnda bir ka kisi de uyarlama, hata 
ayklama ve kodun gelitirilmesi iin alsmt. PostgreSQL'in tredii orijinal Postgres kodu, lisans, lisansst ve 
akademisyenler tarafndan, Professor Michael Stonebraker (University of California, Berkeley) koordinatrlgnde 
yazlmtr.

Berkley'deki yazlmn ad Postgres idi. SQL uyumluluu 1995'te eklenince, ad Postgres 95 oldu. 1996 ylnn 
sonlarnda ad PostgreSQL olarak deitirildi.
1.2) PostgreSQL'in haklar nedir?

PostgreSQL Data Base Management System

Portions copyright (c) 1996-2002, PostgreSQL Global Development Group Portions Copyright (c) 1994-6 Regents of the 
University of California

Permission to use, copy, modify, and distribute this software and its documentation for any purpose, without fee, and 
without a written agreement is hereby granted, provided that the above copyright notice and this paragraph and the 
following two paragraphs appear in all copies.

IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR 
CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF 
THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON AN "AS IS" 
BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR 
MODIFICATIONS.

stteki metin klasik ak-kod lisans olan BSD lisansdr. Kaynak kodun nasl kullanlabileceine dair snrlamalar 
yoktur. Bu lisans seviyoruz. Deitirme niyetimiz bulunmamaktadr.
1.3) PostgreSQL, hangi Unix platforlarnda alr?

Genel olarak, modern bir Unix-uyumlu platform PostgreSQL'i altracaktr. Ayrntl bilgi iin kurulum belgelerine 
bakabilirsiniz.
1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?

PostgreSQL 8.0 srm ile , PostgreSQL artk Win2000, WinXP ve Win2003 gibi Microsoft Windows NT tabanl iletim 
sistemlerinde doal olarak almaya balamtr. Paketlenmi bir  kurulum program, http://pgfoundry.org/projects/pginstaller
adresinden indirilebilir.

Ayrca, http://forge.novell.com adresinde Novell Netware 6 portu bulunmaktadr.
1.5) PostgreSQL'i nereden indirebilirim?

PostgreSQL iin ana anonim ftp sitesi ftp://ftp.PostgreSQL.org/pub adresidir. Yanslar iin, ana web sayfamza 
bakabilirsiniz.
1.6) Nereden destek alabilirim?

Ana e-posta listesi : pgsql-general@@PostgreSQL.org. PostgreSQL konusundaki tartmalara aktr. ye olmak iin, 
aadaki satrlar e-postanzn body ksmna (konu ksmna deil) yazp, pgsql-general-request@@PostgreSQL.org adresine 
gnderin:
d2 210
d215 3
a217 3
Ayn zamanda, bir digest listesi bulunmaktadr. Bu listeye ye olmak iin, pgsql-general-digest-request@@PostgreSQL.org 
adresine, body ksmnda

d221 7
a227 7
yazan bir e-posta atmanz yeterli olacaktr.

Digest postalar, ana liste 30k civarnda e-postaya ulatnda yelere gnderilmektedir.

Bug'lar iin bir e-posta listesi bulunmaktadr. Bu listeye ye olmak iin, pgsql-bugs-request@@PostgreSQL.org adresine, 
body ksmnda

d231 5
a235 5
yazan bir e-posta atmanz yeterli olacaktr.

Ayn zamanda, gelitiriciler iin tartma listesi bulunmaktadr. Bu listeye ye olmak iin, 
pgsql-hackers-request@@PostgreSQL.org adresine, body ksmnda

d239 322
a560 221
yazan bir e-posta atmanz yeterli olacaktr.

Bunun dndaki e-posta listelerine ve PostgreSQL hakknda bilgiye, PostgreSQL WWW ana sayfasndan ulasabilirsiniz: 
http://www.PostgreSQL.org

Ayn zamanda, EFNet zerinde, #PostgreSQL adl bir IRC kanal bulunmaktadr. Bunun iin, irc -c '#PostgreSQL' "$USER" 
irc.phoenix.net Unix komutunu kullanabilirsiniz.

Ticari destek veren firmalarn listesine

http://www.postgresql.org/users-lounge/commercial-support.html

adresinden ulabilirsiniz.
1.7) En son srm nedir?

PostgreSQL'in son srm 7.4.6'dr.

Her 6-8 ayda ana srm karlmas planlanmaktadr.
1.8) Hangi belgelere ulaabilirim?

Datmn iinde, kitapklar, kitapk sayfalar ve baz kk rnekler verilmektedir. /doc dizinine baknz. Ayrca, 
bu el kitapklarn online olarak http://www.PostgreSQL.org/docs/ adresinden inceleyebilirsiniz.

http://www.PostgreSQL.org/docs/awbook.html ve http://www.commandprompt.com/ppbook adreslerinde PostgreSQL kitaplar 
bulunmaktadr. PostgreSQL kitablarnn listesine, http://www.ca.PostgreSQL.org/books/ adresinden ulaaiblirsiniz. 
Ayrca, PostgreSQL konusundaki teknik makalelere de http://techdocs.PostgreSQL.org/ adresinden ulaabilirsiniz.

psql'in, \d ile baslayan veri tipler, operatorler, fonksiyonlar, aggregate'ler, vb. ile ilgili gzel komutlar vardr.

Web sitemiz daha fazla belgeyi iermektedir.
1.9) Bilinen hatalar ya da eksik zelliklere nereden ulaabilirim?

PostgreSQL SQL-92 uyumluluu iindedir, standartlardan fazla da zellikleri bulunmaktadr. Bilinen hatalar, eksik 
zellikler ve gelecek ile ilgili planlar iin TODO listesine baknz.
1.10) Nasl SQL renebilirim?

http:/www.PostgreSQL.org/docs/awbook.html adresindeki kitap SQL gretecektir. http://www.commandprompt.com/ppbook 
adresinde de bir baska PostgreSQL kitab bulunmaktadr.

http://www.intermedia.net/support/sql/sqltut.shtm, 
http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM http://sqlcourse.com ve http://sqlcourse2.com 
adreslerinde de gzel belgeler bulunmaktadr.

Bir bakas da, http://members.tripod.com/er4ebus/sql/index.htm adresinde bulunan "Teach Yourself SQL in 21 Days, 
Second Edition" kitabdr.

Baz kullanclarmz da u kitab nermektedirler: "The Practical SQL Handbook, Bowman, Judith S., et 
al.,Addison-Wesley". Bazlar ise "The Complete Reference SQL, Groff et al., McGraw-Hill" kitabn nermektedirler.
1.11) PostgreSQL 2000 ylna uyumlu mudur?

Evet.
1.12) Gelitirme takmna nasl katlabilirim?

ncelikle, en son kaynak kodunu indirin ve web sitemizdeki ya da datmn iindeki PostgreSQL Developer belgesini 
okuyun. Ardndan, pgsql-hackers ve pgsql-patches listelerine ye olun. nc olarak da, pgsql-pacthes listesine yksek 
kalitede yamalar gnderin.

PostgreSQL CVS arivine eriim izni olan, 10 kadar gelitirici bulunmaktadr. Hepsi defalarca, dier kiilerin 
yaptndan ok daha yksek-kaliteli yamalar gndermilerdir. Ayrca biz de bu gelitiricilerin ekledikleri yamalarn 
yksek kalitede olduuna gveniyoruz.
1.13) Bir hata raporunu nasl gnderebilirim?

PostgreSQL BugTool sayfasna gidiniz. O sayfada bir bug bildirmek iin neleri yapmanz gerektii anlatlmtr.

Ayrca, ftp://ftp.PostgreSQL.org/pub ftp adresimizde, yeni bir PostgreSQL srm ya da yamas olup olmadni kontrol 
ediniz.
1.14) PostgreSQL, diger DBMS'lerle nasl karlastrlabilir?

Bir yazlmn gcn lmek iin eitli yollar vardr: Yazlmn zellikleri, baarm, gvenilirlii, destei ve 
creti.

zellikler:

PostgreSQL mevcut byk ticari veritabanlarnn, transaction, subselect, trigger, view, foreign key referential 
integrity ve sophisticated locking gibi (user-defined types), rules, inheritance ve lock cakmalarn drmek iin 
multi-version uyumluluk zellikleri bulunmaktadr.

Performans (Baarm):

PostgreSQL, dier ticari ve ak kaynak kodlu veritabanlaryla yakn baarm salar. Baz alardan daha hzldr, 
dier alardan da yavatr. MySQL ya da daha zayf veritabanlar ile karlatrldnda, INSERT/UPDATE ilemlerinde, 
transaction bazl alstmz iin daha yavaz. MySQL, yukardaki "zellikler" ksmnda belirtilenlerden hi birine 
sahip deildir. Biz, baarmmz her srmde arttrsak da, esneklik ve gelimi zellikler iin yaplanm durumdayz. 
PostgreSQL'i MySQL ile karlatran u web sitesine bakabilirsiniz: http://openacs.org/why-not-mysql.html

Gvenilirlik:

DBMS'lerin gvenilir olmas gerketii, yoksa deerleri olmayacan dnyoruz. ok iyi test edilmi, dengeli alsan 
minimum sayda hata ieren kod sunmaya alyoruz. Her bir srm en az 1 aylk beta testlerinden geirilmektedir. 
Srm gemiine bakarsanz, retime hazr, dengeli ve kararl kodlar sunduumuzu grebilirsiniz. Bu alanda, dier 
veritaban yazlmlarna stnlmz olduuna inanmaktayz.

Destek:

E-posta listemiz, oluan herhangi bir sorunu zebilecek byk sayda kullanc ve gelitirici grubunu ierir. 
Sorununuz iin, en az bir ticari veritaban kadar rahat zm bulabilirsiniz. Gelistiricilere, kullanc grubuna, 
belgelere ve kaynak koda direk olarak eriebilme, PostgreSQL desteini, dier DBMS'lere gre daha nemli klar. 
Gereksinimi olanlara, ticari destek verilebilir. (Destek iin 1.6 blmne baknz.)

Fiyat:

Ticari ve ticari olmayan tm kullanmlarnz iin PostgreSQL cretsizdir. Kodumuzu, yukarda belirtilen BSD-stili 
lisanstaki snrlamalar hari, rnnzn iine ekleyebilirsiniz.
1.15) PostgreSQL'e maddi adan nasl destek olabilirim?

PostgreSQL, 1996 ylndan beri 1. snf altyapya sahiptir. Bunun iin, yllar boyu alp bu altyapy oluturup 
yneten Marc Fournier'e teekkrler.

Bir ak kaynak kodlu proje iin, kaliteli altyap ok nemlidir. Bu altyap, projenin kesilmesini nler ve projenin 
ilerlemesini hzlandrr.

Tabii ki bu altyap ucuz deildir. lerin yrmesi iin eitli ylk ve anlk harcamalarmz olmaktadr. Eer siz ya 
da irketinizin bu abamza bata bulunabilecek paras varsa, ltfen http://store.pgsql.com adresine gidiniz 
ve bata, hibede bulununuz.

Web sayfasnn 'PostgreSQL Inc.' den bahsetmesine ramen, "katkda bulunanlar" (contributors) maddesi sadece PostgreSQL 
projesini desteklemek iindir ve belirli bir irketin para kayna deildir. isterseniz, balant adresine bir ek 
gnderebilirsiniz.
Kullanc/stemci Sorular
2.1) PostgreSQL icin ODBC srcleri var m?

iki tane ODBC srcs bulunmaktadr: PsqlODBC ve OpenLink ODBC.

PsqlODBC'i http://gborg.postgresql.org/project/psqlodbc/projdisplay.php adresinden indirebilirsiniz.

OpenLink ODBC http://www.openlinksw.com adresinden alnabilir.Bu src, kendi standart ODBC istemci yazlm ile 
alstndan, destekledikleri her platformda (Win, Mac, Unix, VMS) PostgreSQL ODBC bulunmalidir.

cretsiz srm olmakla beraber, ticari kalitede destek almak isteyenlere satmak isteyeceklerdir. Sorularnz ltfen 
postgres95@@openlink.co.uk adresine gnderiniz.
2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar bulunmaktadr?

http://www.webreview.com/ adresinde, arka planda veritaban alstran Web sayfalar iin giri seviyesinde bilgi 
bulunmaktadr.

Web ile btnleme iin, PHP () mkemmel bir arabirim sunar.

Karmak sorunlar iin, ou kisi Perl arabirimini ve CGI.pm ya da mod_perl kullanr.
2.3) PostgreSQL'in grafik kullanc arabirimi var mdr?

eitli grafik arabirimlerimiz bulunmaktadr. Bunlarn arasnda, PgAccess (http://www.pgaccess.org/), PgAdmin II 
(http://www.pgadmin.org/, sadece Win32 iin), RHDB Admin (http://sources.redhat.com/rhdb/) ve Rekall 
(http://www.thekompany.com/products/rekall/) bulunmaktadr. Ayrca, PostgreSQL iin web tabanl bir arabirim olan 
PHPPgAdmin (http://phppgadmin.sourceforge.net/) bulunmaktadr.

Daha ayrntl liste iin http://techdocs.postgresql.org/guides/GUITools adresine bakabilirsiniz.
2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri kullanabilirim?

    * C (libpq)
    * Embedded C (ecpg)
    * Java (jdbc)
    * Python (PyGreSQL)
    * TCL (libpgtcl)

Dierleri iin, http://gborg.postgresql.org adresindeki Drivers/Interfaces blmne bakabilirsiniz.
Ynetimsel Sorular
3.1) PostgreSQL'i, /usr/local/pgsql dizininden baka dizinlere nasl kurabilirim?

configure betiini alstrrken, --prefix seeneini veriniz.
3.2) postmaster'i baslattgmda, a Bad System Call ya da core dumped mesaj alyorum. Neden?

Bunun birok nedeni olabilir. Ancak ilk kontrol edilmesi gereken sey, ekirdeginize System V uzantlarnn kurulu olup 
olmadgn kontrol etmek olabilir. PostgreSQL shared memory ve semaphores iin ekirdek destegine gereksinim duyar.
3.3) postmaster'i balattmda, pcMemoryCreate hatas alyorum. Neden?

Ya ekirdeinizde shared memory desteiniz dzgnce yaplandrlmamtr, ya da ekirdeinizdeki mevcut shared memory 
miktarn bytmeniz gerekecektir. Gereksinim duyacanz miktar, mimarinize ve postmaster iin ayarladgnz tampon 
ile backend ilemi saysna baldr. Tm sistemler iin, tamponlar ve ilemlerde ntanml saylarla, ~ 1MB kadar yere 
gereksinmeniz olacaktr. PostgreSQL 7.3.2 Sistem Yneticileri Rehberi'ne, shared memory ve semaphorelar hakkndaki 
ayrntl bilgi iin bakabilirsiniz.
3.4) postmaster' balattmda, pcSemaphoreCreate hatas alyorum. Neden?

Eer hata, "pcSemaphoreCreate: semget failed (No space left on device)" ise, ekirdeiniz yeterli semaphore ile 
yaplandrlmam demektir. Postgres, her bir potansiyel backend iin bir semaphore gereksinimi duyar. Geici bir 
zm, postmaster backend ilemleri iin daha az miktarda snrla balatmak olabilir. -N'i varsaylan deer olan 
32'den kk bir deerle balatnz. Daha kalc bir zm, ekirdeinizin SEMMNS ve SEMMNI parametrelerini ykseltmek 
olacaktr.

almayan semaphore'lar ar veritaban ilemlerinde kme yaratabilirler.

Eer hata mesajnz baka bir ey ise, ekirdeinizde semaphore desteini yaplandrmam olabilirsiniz. Shared memory 
ve semaphore'lar hakkndaki daha ayrntl bilgi iin PostgreSQL 7.3.2 Sistem Yneticileri Rehberi'ne bakabilirsiniz.
3.5) Diger bilgisayarlarn benim PostgreSQL veritaban sunucuma balantlarn nasl kontrol edebilirim?

n tanml olarak, PostgreSQL sadece yerel makineden Unix domain sockets kullanarak balanlmasna izin verir. Diger 
makineler, postmaster'a -i etiketini geirmezseniz ve $PGDATA/pg_hba.conf dosyasn dzenleyerek host-based 
authentication'a olanak vermezseniz, balant yapamayacaklardr.
3.6) Veritabani motorunu daha iyi baarm iin nasl ayarlayabilirim?

Index'ler sorgular hzlandrabilir. EXPLAIN komutu, PostgreSQL'in sorgunuzu nasl yorumladn ve hangi index'leri 
kullandn grmenize izin verir.

Eer cok fazla INSERT ilemi yapyorsanz, bunlar byk bir toplu ilem dosyaskullanp COPY komutu ile veritabanna 
girmeyi deneyiniz. Bu, tekil INSERT'lerden daha hzldr. kinci olarak, BEGIN WORK/COMMIT transaction blou iinde 
olmayan ifadeler kendi transaction'larndaym gibi dnlr. oklu ifadeleri tek bir transaction blou iinde 
yapabilirsiniz. Bu, transaction overhead'ini drecektir. Tek bir transaction blou iinde birden ok ifadeyi 
altrmay deneyebilirsiniz. Bu da ayn ekilde, transaction overhead'ini drr.

eitli ayarlama seenekleri mevcuttur. fsync() ilemini, postmaster' -o -F seenei ile balatarak devre d 
brakabilirsiniz. Bu ilem, fsync()'lerin her transactiondan sonra diski flush etmesini engelleyecektir.

Ayn zamanda, postmaster'i -B seenei ile balatp, backend ilemleri tarafndan kullanlan shared memory buffers 
saylarn arttrabilirsiniz. Eer bu parametreyi ok yksek tutarsanz, ekirdeinizin shared memory blgesindeki 
limiti ama olaslnz yznden postmaster balayamayabilir. Her bir tampon (buffer) 8K'dr. ntanml say ise 64 
tampondur.

Ayn ekilde, backend'in -S seeneini geici sralamalar iin backend sreleri tarafndan kullanlacak hafzay 
arttrmak amacyla kullanabilirsiniz. -S seenei kilobayt cinsinden deer alr ve n tanml deeri 512'dir (512 K)

Tablolardaki veriyi bir index'e elemek amacyla gruplama iin CLUSTER komutunu kullanabilirsiniz. Ayrntl bilgi iin 
CLUSTER komutunun yardm sayfasna bakabilirsiniz.
3.7) Hangi hata ayklama zellikleri bulunmaktadr?

PostgreSQL, hata ayklama amacyla kullanlabilecek durum bilgisi rapor eden eitli zeliklere sahiptir.

ncelikle, configure betiini --enable-cassert seeneiyle altrrsanz, bir ok assert() backend calmasn 
gzlemler ve beklenmeyen bir durumda program durdurur.

Postmaster ve postgres eitli hata ayklama seeneklerine sahiptir. ncelikle, postmaster' balattnzda, standart 
kty ve hatalar bir log dosyasna ynlendirdiinize emin olun:

d564 124
a687 78
Bu ilem PostgreSQL ana dizinine server.log dosyas yerletirecektir. Bu dosya sunucunun yaad sorunlar ya da 
hatalar hakknda yararl bilgiler ierir. -d seenei, hata ayklama seviyesini belirten bir rakam ile kullanlr. 
Yksek hata ayklama seviyelerinin byk log dosyalar oluturacan unutmaynz.

Eer postmaster almyorsa, postgres backend'ini komut satrndan altrabilir ve SQL ifadenizi direk olarak 
yazabilirsiniz. Bu sadece hata ayklama amacyla nerilir. Burada, noktal virgln deil de yeni bir satrn sorguyu 
sonlandrdn unutmaynz. Eer hata ayklama sembolleri ile derlediyseniz, ne olduunu grmek iin bir hata 
ayklayc kullanabilirsiniz. backend postmaster'dan balatlmadndan, edeer bir ortamda almamaktadr ve 
locking/backend etkileim sorunlar artabilir.

Eer postmaster alyorsa, bir pencerede psql'i altrn ve psql tarafndan kullanlan postgres srecinin sre 
numarasn (PID) bulun. Postgres sreci ile ilikilendirmek iin bir hata ayklarc kullann. Sorgular psql aracl 
ile altrabilirsiniz. Eer postgres balangcnda hata ayklamak istiyorsanz, PGOPTIONS="-W n" seeneini 
ayarlayabilir ve psql'i balatabilirsiniz. Bu ilem, balangcn n saniye kadar gecikmesini salayacaktr; bylece hata 
ayklaycy srece ilikilendirdikten sonra balang srecinin devam etmesini salayabilirsiniz.

postgres program hata ayklama ve baarm lmleri iin -s, -A ve -t seeneklerine sahiptir.
3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn alyorum?

Postmaster'n ezamanl olarak balatabilecei backend sreleri snrlarn arttrmanz gerekmektedir.

n tanml deer 32 sretir. Bunu, postmaster' uygun -N deeri ile ya da postgresql.conf dosyasn dzenleyerek 
yeniden balatmakla arttrabilirsiniz.

Eer -N deerini 32'den byk yapacaksanz, ayn zamanda -B deerini de deitirmeniz gerektiini unutmayn. -B, -N'nin 
en az 2 kat kadar olmaldr; daha iyi baarm iin bu sayy daha da arttrmalsnz. Yksek saydaki backend 
sreleri iin, eitli ekirdek yaplandrma parametrelerini arttrmanz gerekecektir. Yaplmas gerekenler, SHMMAX, 
SEMMNS, SEMMNI, NPROC, MAXUPRC ve alabilecek dosyalarn maksimum says olan NFILE ve NINODE deerlerini 
kartrmaktr. Bunun nedeni, PostgreSQL'in izin verilen backend srelerinin says zerinde bir snr olmasdr. 
Bylelikle sistem kaynaklarnn dna klmayacaktr.

PostgreSQL'in 6.5 srmne kadar, en fazla backend says 64 idi ve bunu deitirmek iin include/storage/sinvaladt.h 
dosyas iindeki MaxBAckendid sabitini deitirdek sonra yazlm yeniden derlemek gerekiyordu.
3.9) pgsql_tmp dizinin iindeki dosyalar nelerdir?

Sorgu alstrc (query executer) tarafndan yaratlan geici dosyalardr. rnegin, bir sralama ORDER BY ile 
yaplacaksa ve sralama backend'in -s parametresinin izin verdiinden daha fazla alana gereksinim duyuyorsa, ekstra 
veriyi tutmak iin geici dosyalar yaratlr.

Geici dosyalar, eer sralama srasnda backend gmezse otomatik olarak silinecektir. Eer alan durumda bir 
backend'iniz yoksa, pg_tempNNN.NN dosyalarn silmeniz gvenlidir.
3.10) PostgreSQL srmlerini ykseltmek iin neden bir dump/reload ilemi gerekletirmek zorundaym?

PostgreSQL takm ara srmlerde sadece kk deiiklikler yapmaktadr; bu yzden 7.2 srmnden 7.2.1'e ykseltmek 
dump/restore ilemi gerekmemektedir. Ancak, esas srmlerde (rnek: 7.2'den 7.3'e) ounlukla sistem tablolarnn ve 
veri dosyalarnn i yaps deitirilir. Bu deiiklikler ounlukla karmaktr; dolaysyla veri dosyalarnn geriye 
dnk uyumluluu ilemlerini yapmyoruz. Dump ilemi, veriyi genel biimde alacandan yeniden ykleme esnasnda veri, 
yeni i biime uygun ekilde yerletirilecektir.

Disk biiminin deimedii srmlerde, pg_upgrade betii gncellemenin bir dump/restore gerektirmeden yaplmasn 
salayacaktr. pg_upgrade betiinin o srm iin bulunup bulunmadn srm notlar iinde bulabilirsiniz.
3.11) Nasl bir donanm kullanmalym?

PC donanm tamamen uyumlu olduu iin, insanlar tm PC donanmlarnn ayn kalitede olduunu dnrler. Oysa byle 
deildir. ECC RAM, SCSI ve kaliteli anakartlar daha ucuz donanmlara gre daha ok gvenilirlerdir ve baarmlar daha 
yksektir. PostgreSQL hemen hemen tm donanmda alabilmektedir, ancak gvenilirlik ve baarm nemli ise donanm 
seeneklerini ok iyi aratrmak gereklidir. E-posta listelerimi donanmlarla ilgili sorular ve de ticaret iin 
kullanlabilir.
letimsel Sorular
4.1) Binary cursor ve normal cursor arasndaki fark nedir?

DECLARE yardm sayfasna baknz.
4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?

FETCH yardm sayfasna baknz, ya da SELECT ... LIMIT ... kullannz.

lk birka satr almak isteseniz bile, tm sorgu deerlendirilmek durumunda kalnabilir. ORDER BY ieren bir sorgu 
dnn. Eer ORDER BY ie eleen bir index varsa, PostgreSQL istenen ilk birka satr ileyebilir, ya da tm sorgu 
istenen satrlar retilene kadar ilenebilir.
4.3) psql'in iinde grdgm tablolarn ya da dier eylerin listesini nasl alabilirim?

pgsql/src/bin/psql/describe.c iindeki psql kaynak kodunu okuyabilirsiniz. Bu kod, psql'in \ ile balayan komutlarnn 
ktsn olusturan SQL komutlarn ierir. Ayn zamanda, psql'i -E seenei ile balatp, verdiiniz komutlar 
altrmak iin yapt sorgularn ktlarn grebilirsiniz.
4.4) Bir tablodan bir kolonu nasl kaldrabilirim?

Bu zellik (ALTER TABLE DROP COLUMN) 7.3 srm ile gelmitir. Eski srmlerde aadakileri uygulamalsnz:

d695 44
a738 45
COMMIT;		
		

4.5) Bir satr, tablo ve veritaban iin en fazla byklk nedir?

Snrlar:

Veritaban iin en fazla byklk nedir?
Snrsz (32 TB'lk veritaban bulunmaktadr)

Bir tablo iin en fazla byklk nedir?
32 TB

Bir satr iin en fazla byklk nedir?
1.6 TB

Bir alan iin en fazla byklk nedir?
1 GB

Tabloda en fazla satr says katr?
Snrsz

Bir tabloda olabilecek en fazla kolon says katr?
Kolon tiplerine bal olarak 250-1600

Bir tabloda olabilecek en fazla index says katr?
Snrsz

Tabii ki bunlar aslnda snrsz degildir. Burada belirtilen snrlar, fiziksel snrlarn haricindeki snrlardr. Bo 
disk alan, hafza/takas alan na bal snrlamalar vardr. Baarm, snr deerlere yaklatka, ya da deerler ok 
byk olduunda debilir.

Bir tablo iin byklk snr olan 32 TB, iletim sisteminin byk dosya destei olup olmamasndan bamszdr. Byk 
tablolar, 1 GB'lik dosyalarda sakland iin, dosya sistemi snrlarnin bir nemi yoktur.

Tablo ve kolon says byklkleri, n tanml blok bykl 32k ya karlarak arttrlabilir.
4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk alan gereklidir?

Bir PostgreSQL veritaban, veriyi "flat" metin dosyasnda saklamak iin gereken alann 5 kat fazla disk alanna 
gereksinim duyabilir.

Her satrnda bir tamsay ve metin (text) ieren, 100.000 satrlk bir dosya dnn. Her satrn ortalama 20 byte 
olduunu farzedelim. Metin dosyas 2.8 MB olacaktr. Bu veriyi tutan PostgreSQL veritaban yaklak 6.4 MB yer 
kaplayacaktr.

d740 1
a740 1
+ 24 byte: Bir tamsay (int) alan ve bir metin (text) alan 
d745 2
a746 2
PostgreSQL'de veri sayfas (data page) bykl 8192 byte (8k)dr, dolaysyla:

d750 1
a750 1
  
d755 48
a802 32
782 veritaban sayfas * sayfa bana 8192 byte = 6,406,144 bytes (6.4 MB)

Index'ler ok fazla yere gereksinim duymazlar, ama index'lenmi veriyi tutacaklarndan byk olabilirler.

NULL deerler bitmapler iinde tutulur; dolaysyla ok az yer kaplarlar.
4.7) Veritabannda hangi tablo ya da index'lerin tanmlandn nasl grebilirim?

psql, bu tr bilgileri gstermek iin, \ ile balayan bir ok komut sunmaktadr. \? komutu ile bu komutlar 
grebilirsiniz. Ayrca, bunlar aklayan ve pg_ ile balayan ok sayda sistem tablosu bulunmaktadr. Ayn zamanda, 
psql -l ile tm veritabanlarn listeyelebirsiniz.

Ayrca, pgsql/src/tutorial/syscat.source kodunu inceleyebilirsiniz. Bu dosya, veritaban sistem dosyalarndan bilgiyi 
almak iin gereksinim duyulan bir ok SELECT'leri gsterir.
4.8) Sorgularm cok yava, ya da index'lerimi kullanmyorlar. Neden?

Indexler her sorgu tarafndan otomatik olarak kullanlmazlar. Indexler eer bir tablonun bykl minimum bir 
byklkten fazla ise ve sorgu tablodaki satrlarn sadece kk bir yzdesini seiyorsa kullanlr. Bunun nedeni, 
index eriiminin neden olduu raslansal disk eriimi nin diskin ya da tablonun sral okunmasndan daha yavas 
olabilmesidir.

Bir index'in kullanlp kullanlmayacan belirlemek iin, PostgreSQL tablo hakkndaki istatistiklere gereksinmesi 
vardr. Bu istatistikler, VACUUM ANALYZE kullanlarak toplanrlar. Optimizer, istatistikleri kullanarak, tabloda ka 
satr olduunu ve bilir ve indexin kullanlp kullanlmayacana daha iyi karar verir. Istatistikler, ayn zamanda en 
uygun join srasn ve yntemini belirlemekte ok nemlidir. statistik toplanmas, tablo ierikleri deitike 
periyodik olarak yaplmaldr.

Indexler normalde ORDER BY sorgular ya da join ilemlerini gerekletirmek iin kullanlmazlar. Ak bir sralamay 
takip eden sral bir arama (sequential scan), byk bir tabloda index aramas yapmaktan genelde daha hzldr.
Ancak, ORDER BY ile birlemi LIMIT genellikle bir index kullanacaktr; nk tablonun sadece belirli bir miktar 
dndrlecektir. Aslnda, MAX() ve MIN() fonksiyonlarnn index kullanmamalarndan dolay, bu gibi deerleri ORDER BY 
ve LIMIT kullanarak da almak olasdr:

d808 59
a866 43
Eer optimizer'n sral arama yapmasnn yanl olduuna inanyorsanz, SET enable_seqscan TO 'off' kullann ve index 
kullanan aramalarn hala daha hzl olup olmadn grn.

LIKE ya da ~ gibi operatrler kullanyorsanz, index'ler sadece aadaki koullarda kullanlabilir:

    * Arama dizininin ba, dizinin ba ile balanmaldr. Yani,
          o LIKE sorgular % ile balamamaldr.
          o Dzenli ifade sorgular ^ ie balamamaldr.
    * Arama metni bir karakter snf ile balayamaz. rnek: [a-e]
    * ILIKE ve ~* gibi byk/kk harfe duyarsz aramalar index'lerden yararlanmazlar. Onun yerine, blm 4.12'de 
anlatlan fonksiyonel index'leri kullanabilirsiniz.
    * initdb srasnda ntanml C locale'i kullanlmaldr.

4.9) query-optimizer'n sorgularm nasl deerlendirdiini, ileme soktuunu nasl grebilirim?

EXPLAIN yardm sayfasna baknz.
4.10) R-tree index nedir?

R-tree index, uzaysal (spatial) verileri indexlemek iin kullanlr. Bir hash index, dizi aramalarnda (range search) 
kullanlamaz. B-tree index dizi aramalarnda sadece tek boyutlu almaktadr. R-tree, ok boyutlu veriyi destekler. 
rnein, eer bir R-tree index point veri tipi zerinde ina edililebilirse, sistem "select all points within a 
bounding rectangle" gibi sorgulara daha verimli yantlar verecektir.

Orijinal R-tree tasarmn aklayan belge:

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.

Bu belgeyi, Stonebraker'n "Readings in Database Systems" kitabnda bulabilirsiniz.

Gml R-tree indexleri poligon ve boxlar kullanabilir. Teorik olarak, R-tree indexlerin zelliklerini geniletmek bir 
miktar aba gerektirir ve bunun nasl yaplacana dair bir belgemiz henz bulunmamaktadr.
4.11) Genetic Query Optimizer nedir?

GEQO modl, Genetic Algorithm(GA) kullanlarak tablolar birletirildiinde sorgu optimizasyonunu hzlandrr.
4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasl yapabilirim? Bu 
byk(kk harfe duyarl aramalar iin index'i nasl kullanabilirim?

~ operatr dzenli ifade elemesi ve ~* byk/kk harfe duyarsz dzenli ifade elemesi yapar. Byk/kk harfe 
duyarl olan LIKE'n byk/kk harfe duyarsz olan biimi ILIKE'tr ve PostgreSQL 7.1 srm ile birlikte gelmitir.

Byk-kk harfe duyarsz eitlik karlatrmalar aadaki gibi ifade edilir:

d870 3
a872 4
		

Bu standart bir index yaratmayacaktr. Ancak eer fonksiyonel bir index yaratrsanz; o kullanlacaktr:

d875 7
a881 6
4.13) Bir sorguda, bir alanin "NULL" olduunu nasl ortaya karabilirim?

Kolonu, IS NULL ve IS NOT NULL ile test edebilirsiniz.
4.14) esitli karakter tipleri arasndaki farklar nelerdir?

Veri Tipi	     Ad              Not
d885 1
a885 1
TEXT            text            uzunlukta herhangi bir st snr yoktur. 
d887 27
a913 19
"char"          char            bir karakter 
		

 adlar (internal name) sistem kataloglarn ve baz hata mesajlarn incelerken greceksiniz.

lk drt veri tipi "varlena" tipidir (yani, diskteki ilk 4 bayt uzunluktur; devam da veridir.) Dolaysyla, kullanlan 
gerek alan, belirtilen alandan biraz daha byktr. Ancak, bu veri tipleri, sktrlmaya tabi tutulabilir; 
dolaysyla disk alan beklenilenden kk olabilir. VARCHAR(n) bykl artabilen ama en byk uzunluu snrl olan 
verileri saklamak iin en uygun yntemdir. TEXT, 1 GB bykle kadar olan verileri tutmak iin kullanlr.

CHAR(n), ayn uzunluktaki dizilerin saklanmas iin kullanmr. CHAR(n) belirtilen uzunlua kadar boluk ile doldurur; 
ancak VARCHAR(n) sadece verilen karakterleri saklar. BYTEA binary veri saklamak iindir; ayrca "NULL" bayt ieren 
deerleri de saklar. Burada anlatlan  veri tipi de benzer baarm karakteristiklere sahiptir.
4.15.1) Nasl serial/otomatik artan (auto-incrementing) bir alan yaratabilirim?

PostgreSQL'de SERIAL veri tipi vardr. Bu veri tipi bir sequence ve kolon zerinde bir index yaratr.

rnek, aadaki sorgu:

d917 3
a919 5
);		
		

buna evrilir:

d925 14
a938 11
CREATE UNIQUE INDEX person_id_key ON person ( id );		
		

Sequenceler hakknda daha fazla bilgi iin create_sequence yardm sayfasna bakabilirsiniz. Her satrn OID alann 
tekil bir say olarak alabilirsiniz. Ancak, veritabannzn dump'n alp yeniden yklerseniz, OID deerlerini 
koruyabilmek iin pg_dump'n -o parametresini ya da "COPY WITH OIDS" seeneini kullanmanz gerekecektir.
4.15.2) SERIAL giriinin degerini nasl alabilirim?

Bir yaklam, sequence nesnesindeki SERIAL deerini, veriyi girmeden nce nextval() ile alp, aldnz deeri 
kendinizin girmesidir. 4.15.1'deki rnek tabloyu kullanarak bir rnek verelim:

d943 88
a1030 68
Dier sorgular iin new_id'de yeni deerin saklanmas gerekir. Otomatik olarak yaratlan SEQUENE nesnesinin ad, __seq 
eklinde olacaktr (< > iaretleri olmadan).

Alternatif olarak, atanm SERIAL deerini, deer girildikten sonra currval() fonksiyonu ile alabilirsiniz:

		execute("INSERT INTO person (name) VALUES ('Blaise Pascal')");
		new_id = execute("SELECT currval('person_id_seq')");	
		

Son olarak, n tanml deeri bulmak iin INSERT ifadesinden dnen OID deerini kullanabilirsiniz; ancak bu en az 
tanabilir zm olacaktr. Perl'de, Edmund Mergl'in DBD:Pg mdl ile birlikte DBI kullanarak, OID deeri 
$sth->execute() altrldktan sonra $sth->(pg_oid_status) ile alnabilir.
4.15.3) currval() ve nextval() dier kullanclara sorun yaratmaz m?

Hayr. curval(), tm kullanclar deil, backend tarafndan atanan geerli deeri dndrr.
4.15.4) Neden sequence saylar transaction ileminin iptalinden sonra yeniden kullanlyor? Neden sequence/SERIAL 
kolonumdaki saylarda atlamalar oluyor?

Uyumluluu arttrmak iin, sequence deerleri alan transaction'lara gerektii ekilde aktarlr ve transaction 
bitene kadar o deer kilitlenmez. Bu, iptal edilen transaction ilemleri nedeniyle boluklara neden olur.
4.16) OID nedir? TID nedir?

OIDler, tekil satr numaralarna PostgreSQL'in yantdr. PostgreSQL'de yaratlan her say, tekil bir OID alr. initdb 
ilemi srasnda yaratlan tm OID'ler 16384'ten kktr (backend/access/transam.h). Kullanclar tarafndan yaratlan 
tm OID'ler bu sayya eit ya da bu saydan byktr. Varsaylan durumda, tm bu OIDler sadece bir tablo ya da 
veritabannda deil, tm PostgreSQL kurulumunda tekildir.

PostgreSQL OIDleri, tablolar arasnda satrlar ilikilendirmek iin kendi i tablolarnda kullanr. Bu OIDler belirli 
kullanc satrlarn belirtmek iin kullanabilir ve join ilemlerinde kullanlr. OID deerlerini saklamak iin OID 
kolon tipini kullanmanz nerinir. Daha hzl bir eriim iin, OID alannda bir index yaratabilirsiniz.

OID'ler yeni satrlara, tm veritabanlar tarafnda kullanlan ortak bir alandan atanrlar. Eer OID'i baka bir deere 
eitlemek isterseniz ya da tablonun bir kopyasn orijinal OIDler ile karmak isterseniz, bu mmkndr:

			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';		
		

OIDler 4-bit tamsay olarak saklanrlar ve 4 milyarda overflow olacaktr. Kimse bu sayya ulatna dair bir bilgi 
iletmedi ve bu snr kimse bu snra ulamadan kaldracaz.

TIDler, belirli fiziksel satrlar block ve offset deerleri ile belirtmekte kullanlr. TIDler, satrlar deitiinde 
ya da yeniden yklendiinde deiirler. Index girdileri tarafndan fiziksel satrlar gstermek iin kullanlrlar.

4.17) PostgreSQL'de kullanlan baz terimlerin anlamlar nelerdir?

Kaynak kodun bir ksm ve eski belgeler, daha geni kullanm alan olan terimleri kullanrlar. Bunlarn bazlar:

    * table, relation, class
    * row, record, tuple
    * column, field, attribute
    * retrieve, select
    * replace, update
    * append, insert
    * OID, serial value
    * portal, cursor
    * range variable, table name, table alias

Genel veritaban terimleri, http://hea-www.harvard.edu/MST/simul/software/docs/pkgs/pgsql/glossary/glossary.html 
adresinde bulunabilir.
4.18) Neden "ERROR: Memory exhausted in AllocSetAlloc()" hatasn alyorum?

Sisteminizde sanal belleinizi tketmi olabilirsiniz, ya da ekirdeiniz belli kaynaklar icin dk bir snra sahip 
olabilir. postmaster' balatmadan nce aadakileri deneyebilirsiniz:

d1032 33
a1064 25
limit datasize 256m		
		

Kabuunuza bal olarak, bunlardan sadece biri olumlu sonu verecektir, ama bu ilem veri segment snrnz 
arttracak, ve belki de sorgunuzun tamamlanmasn salayacaktr. Bu komut, varolan ileme (current process) ve komut 
altrldktan sonraki tm alt ilemlere uygulanr. Eer SQL istemcinizle, backend'in ok fazla veri dndrmesi 
nedeniyle bir sorun yayorsanz, bunu istemciyi balatmadan nce deneyiniz.
4.19) Hangi PostgreSQL srmn altrdm nasl grebilirim?

psql arabiriminde, select version(); yaznz.
4.20) Neden large-object ilemlerim, "invalid large obj descriptor" hatasn veriyor?

Large object ilemlerinizin ularna, yani lo_open ... lo_close komutlarnn evresine, BEGIN WORK ve COMMIT koymanz 
gerekmektedir;

u anda, PostgreSQL kurallar large objectleri transaction commit edildiinde kapatarak uygulamaktadr. Dolaysyla 
handle ile yaplacak ilk ey invalid large obj descriptor hatas ile sonulanacaktr.Dolaysyla alan kodunuz eer 
transaction kullanmazsanz hata mesajlar retecektir.

Eer ODBC gibi bir istemci arabirimi kullanyorsanz, auto-commit'i kapatmanz gerekebilir.
4.21) u andaki zaman ntanml deer olarak kabul eden How do I create a column that will default to the current 
time?

Alttakini kullanabilirsiniz:

d1067 6
a1072 7
		

4.22) Neden IN kullanan subquery'lerim ok yavas?

7.4 srmnden nce, subqueryler. Eer subquery sadece birka satr ve outer query bol sayda satr dndryorsa, IN en 
hzlsdr. Sorgular hzlandrmak iin IN yerine EXISTS kullann:

d1076 2
a1077 4
		

sorgusunu, aadaki ile deitirin:

d1080 12
a1091 11
    WHERE EXISTS (SELECT col2 FROM TAB2 WHERE col1 = col2)		
		

Bu ilemin hzl olmas iin, subcol'un indexlenmi bir kolon olmas gerekmektedir.

7.4 srm ve sonrasnda, IN aslnda normal sorgularla ayn karmak join tekniklerini kullanr ve EXISTS'e tercih 
edilir.
4.23) Outer join ilemini nasl yapabilirim?

PostgreSQL outer joins islemlerini SQL standartlarn kullanarak gerekletirmektedir. Aada 2 rnek bulunmaktadr:

d1093 3
a1095 5
FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);		
		

ya da

d1097 13
a1109 11
FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);		
		

Bu zde sorgular t1.col' i t2.col'ye join ederler ve ayn zamanda t1'deki unjoined satrlar (t2'de elenmemi 
olanlarla) dndrrler. RIGHT JOIN t2'nin unjoined satrlarn ekleyecektir. Bir FULL join, elemi btn satrlar ve 
t1 ile t2'den tm balanmam (unjoined) satrlar alr. OUTER szc seimseldir ve LEFT, RIGHT ve FULL join 
ilemlerinde olduu kabul edilir. Sradan join ilemleri INNER JOIN olarak adlandrlr.

nceki srmlerde, OUTER JOINler UNION ve NOT IN kullanlarak simle edilebiliyordu. rnein, tab1 ve tab2'yi 
birletirirken, aadaki sorgu iki tablonun dtan balanmasn salar:

d1117 76
a1192 57
ORDER BY col1		
		

4.24) Ayn andan birden fazla veritabannda nasl ilem yapabilirim?

Mevcut veritabannz dndaki baka bir veritabannz sorgulamanzn bir yolu bulunmamaktadr. Bunun nedeni, 
PostgreSQL'in veritabanna zel sistem kataloglar yklemesidir. Bu nedenle, cross-database bir sorgunun nasl 
davranacan kestirmek zordur.

contrib/dblink fonksiyon arlarn kullanarak cross-database sorgulara izin verir. Tabii ki, bir istemci deiik 
veritabanlarna ayn anda eriim salayabilir ve bilgiyi bu ekilde birletirebilir.

4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?

7.3 srmnde, bir fonksiyondan kolaylkla oklu satr ya da stun dndrebilirsiniz. 
(http://techdocs.postgresql.org/guides/SetReturningFunctions)

4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?

PL/PgSQL fonksiyon ierikleri cache'ler. Bunun istenmeyen bir taraf, eer bir PL/PgSQL fonksiyonu geici bir tabloya 
eriiyorsa ve bu tablo ileride kaldrlp yeniden oluturulduktan sonra fonksiyon yeniden arlrsa, fonksiyon 
almayacaktr; nk cache'lenmi fonksiyon hala eski geici tabloyu gsteriyor olacaktr. zm, geici tablo 
eriimleri iin PL/PgSQL'de EXECUTE kullanmaktr. Bu, sorgunun her seferinde yeniden ilenmesini salayacaktr.

4.27) Hangi ifreleme seenekleri bulunmaktadr?

    * contrib/pgcrypto SQL sorgularnda kullanlabilmesi iin ifreleme fonksiyonlar iermektedir.
    * stemciden sunucuya iletiimi ifrelemek iin, sunucuda ssl seenei postgresql.conf iinde ak olmaldr. 
Ayrca,pg_hba.conf dosyas iinde host ya da hostssl kayd mutlaka olmaldr ve istemci sslmode kapatlmamaldr. (Ayn 
zamanda,PostgreSQL'in doal SSL balantlar dnda ssh ya da ssl gibi 3.parti ifrelenmi veri iletimi de mmkndr.)
    * Veritaban kullanc ad ve ifreleri 7.3 srm ile birlikte otomatik olarak ifrelenirler. nceki srmlerde, 
postgresql.conf iindeki PASSWORD_ENCRYPTION seeneini aktif hale getirmeniz gerekmektedir.
    * Sunucunun kendisini ifreli dosya sistemi zerinde altrabilirsiniz.

PostgreSQL zelliklerini Geniletmek

5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman neden core dump ediyor?

Sorunun nedeni birden fazla ey olabilir. Kullanc-tanml fonksiyonunuzu stand-alone bir programda altrmay 
deneyiniz.

5.2) PostgreSQL'e nasl yeni tipler/fonksiyonlar ekleyebilirim?

almalarnz pgsql-hackers e-posta listesine gnderiniz. Kodunuz incelendikten sonra /contrib dizinine konacaktr.

5.3) Bir tuple dondrmek icin bir C fonksiyonunu nasil yazarm?

PostgreSQL 7.3 srm ile birlikte, C, PL/PgSQL ve SQL kullanlarak tablo-dndren fonksiyonlar tamamen 
desteklenmektedir. Ayrntl bilgi iin PostgreSQL 7.3.2 Kullanc Rehberi'ne bakabilrisiniz. Bir rnei 
contrib/tablefunc iinde bulabilirsiniz.

5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen deiiklik geerli olmuyor. Neden?

Makefile'lar include dosyalar iin tam bir bamllk iermezler. ncelikle make clean, ardndan da baska bir make 
ilemi yapmanz gerekir. GCC kullanyorsanz, configure betiinin --enable-depend seeneini, derleyicinin 
bamllklar otomatik olarak hesaplamas iin kullanabilirsiniz.

@


1.6.4.1
log
@Here's the patch to fix a lot of markup errors in the HTML FAQs. Doesn't
change content (at least not supposed to).

Magnus Hagander
@
text
@d1 147
a148 210
                  PostgreSQL iin Ska Sorulan Sorular (SSS)
                                       
   Son gncelleme : 15 Kasm 2004 Pazartesi - 15:03:23
   
   Current maintainer: Bruce Momjian (pgman@@candle.pha.pa.us)
   
   evirenler : Devrim Gndz (devrim@@tdmsoft.com)
   Nicolai Tufar (ntufar@@tdmsoft.com)
   Volkan YAZICI (volkany@@phreaker.net)
   
   Bu belgenin en gncel hali,
   http://www.PostgreSQL.org/docs/faqs/FAQ_turkish.html ve
   http://www.gunduz.org/seminer/pg/FAQ_turkish.html adreslerinde
   grlebilir.
   
   Platforma zel sorularnz, http://www.PostgreSQL.org/docs/index.html
   adresinde yantlanr.
     _________________________________________________________________
   
                               Genel Sorular
                                      
   1.1) PostgreSQL nedir? Nasl okunur?
   1.2) PostgreSQL'in haklar nedir?
   1.3) PostgreSQL, hangi Unix platformlarnda alr?
   1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
   1.5) PostgreSQL'i nereden indirebilirim?
   1.6) Destei nereden alabilirim?
   1.7) En son srm nedir?
   1.8) Hangi belgelere ulaabilirim?
   1.9) Bilinen hatalar ya da eksik zelliklere nereden ulasabilirim?
   1.10) Nasl SQL renebilirim?
   1.11) PostgreSQL 2000 ylna uyumlu mudur?
   1.12) Gelitirme takmna nasl katlabilirim??
   1.13) Bir hata raporunu nasl gnderebilirim?
   1.14) PostgreSQL, dier VTYS(DBMS) lerle nasl karlatrlabilir?
   1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
   
                         Kullanc/istemci Sorular
                                      
   2.1) PostgreSQL iin ODBC srcleri var m?
   2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar
   bulunmaktadr?
   2.3) PostgreSQL'in grafik kullanc arabirimi var mdr?
   2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri
   kullanabilirim?
   
                             Ynetimsel Sorular
                                      
   3.1) PostgreSQL'i /usr/local/pgsql dizininden baka dizinlere nasl
   kurabilirim?
   3.2) Postmaster' balattmda Bad System Call ya da core dumped
   mesaj alyorum. Neden?
   3.3) Postmaster' balattmda, IpcMemoryCreate hatas alyorum.
   Neden?
   3.4) Postmaster', balattmda, IpcSemaphoreCreate hatas alyorum.
   Neden?
   3.5) Dier bilgisayarlarn benim PostgreSQL veritaban sunucuma
   balantlarn nasl kontrol edebilirim?
   3.6) Veritaban motorunu daha iyi baarm icin nasl ayarlayabilirim?
   3.7) Hangi hata ayklama zellikleri bulunmaktadr?
   3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn
   alyorum. Neden?
   3.9) pgsql_tmpdizinin iindeki dosyalar nelerdir?
   3.10) PostgreSQL srmlerini ykseltmek iin neden bir dump/reload
   ilemi gerekletirmek zorundaym?
   3.11) Nasl bir donanm kullanmalym?br>
   
                             letimsel Sorular
                                      
   4.1) Binary cursor ve normal cursor arasndaki fark nedr?
   4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
   4.3) psql'in iinde grdgm tablolarn ya da dier eylerin listesini
   nasl alabilirim?
   4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
   4.5) Bir satr, tablo ve veritaban iin en fazla byklk nedir?
   4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk
   alan gereklidir?
   4.7) Veritabannda hangi tablo ya da index'lerin tanmlandn nasl
   grebilirim?
   4.8) Sorgularm cok yava, ya da index'lerimi kullanmyorlar. Neden?
   4.9) Query-optimizer'n sorgularm nasl deerlendirdiini, ileme
   soktuunu nasl grebilirim?
   4.10) R-tree index nedir?
   4.11) Genetic Query Optimizer nedir?
   4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk
   harfe duyarsz aramalar nasl yapabilirim? Bu byk/kk harfe
   duyarl aramalar iin index'i nasl kullanabilirim?
   4.13) Bir sorguda, bir alann NULL olduunu nasl ortaya
   karabilirim?
   4.14) esitli karakter tipleri arasndaki farklar nelerdir?
   4.15.1) Nasl serial/otomatik artan (auto-incrementing) bir alan
   yaratabilirim?
   4.15.2) Serial giriinin deerini nasl alabilirim?
   4.15.3) currval() ve nextval() dier kullanclara sorun yaratmaz m?
   4.15.4) Neden sequence saylarn transaction ileminin iptalinden
   sonra yeniden kullanlyor? Neden sequence/SERIAL kolonumdaki
   saylarda atlamalar oluyor?
   4.16) OID nedir? TID nedir?
   4.17) PostgreSQL' de kullanlan baz terimlerin anlamlar nelerdir?
   4.18) Neden "ERROR: Memory exhausted in AllocSetAlloc()" hatasn
   alyorum?
   4.19) Hangi PostgreSQL srmn alstrdm nasl grebilirim?
   4.20) Neden large-object ilemlerim, "invalid large obj descriptor"
   hatasn veriyor?
   4.21) u andaki zaman ntanml deer olarak kabul eden kolonu nasl
   yaratrm?
   4.22) Neden IN kullanan subquery'lerim ok yava?
   4.23) Outer join ilemini nasl yapabilirim?
   4.24) Ayn anda birden fazla veritabannda nasl ilem yapabilirim?
   4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?
   4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo
   yaratma/kaldrma ilemlerini yapamyoruz?
   4.27) Hangi ifreleme seenekleri bulunmaktadr?
   
                    PostgreSQL zelliklerini Geniletmek
                                      
   5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm
   zaman neden core dump ediyor?
   5.2) PostgreSQL'e nasl yeni veri tipleri/fonksiyonlar ekleyebilirim?
   5.3) Bir tuple dndrmek iin bir C fonksiyonunu nasl yazarm?
   5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen
   deiiklik geerli olmuyor. Neden?
     _________________________________________________________________
   
                               Genel Sorular
                                      
    1.1) PostgreSQL nedir? Nasl okunur?
    
   PostgreSQL, Post-Gres-Q-L. olarak okunur
   
   PostgreSQL, yeni-nesil VTYS aratrma prototipi olan POSTGRES
   veritaban ynetim sisteminin gelitirilmesidir. POSTGRES'in zengin
   veri tiplerini ve gl veri modelini tutarken, SQL'in gelitirilmi
   alt kmesi olan PostQuel dilini kullanr. PostgreSQL cretsizdir ve
   kaynak kodu ak datlr.
   
   PostgreSQL, PostgreSQL gelitirme listesine ye olan bir Internet
   gelitirici takm tarafndan gelitirilir. u andaki koordinatr,
   Marc G. Fournier (scrappy@@PostgreSQL.org). (Bu takma nasl
   katlacagnz renmek iin 1.6 numaral maddeyi okuyunuz.) Bu takm,
   tm PostgreSQL geliiminden sorumludur.
   
   PostgreSQL 1.01 srmnn yazarlar Andrew Yu ve Jolly Chen idi.
   Bunlarn dnda bir ka kisi de uyarlama, hata ayklama ve kodun
   gelitirilmesi iin alsmt. PostgreSQL'in tredii orijinal
   Postgres kodu, lisans, lisansst ve akademisyenler tarafndan,
   Professor Michael Stonebraker (University of California, Berkeley)
   koordinatrlgnde yazlmtr.
   
   Berkley'deki yazlmn ad Postgres idi. SQL uyumluluu 1995'te
   eklenince, ad Postgres 95 oldu. 1996 ylnn sonlarnda ad
   PostgreSQL olarak deitirildi.
   
    1.2) PostgreSQL'in haklar nedir?
    
   PostgreSQL Data Base Management System
   
   Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
   Portions Copyright (c) 1994-6 Regents of the University of California
   
   Permission to use, copy, modify, and distribute this software and its
   documentation for any purpose, without fee, and without a written
   agreement is hereby granted, provided that the above copyright notice
   and this paragraph and the following two paragraphs appear in all
   copies.
   
   IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY
   FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES,
   INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND
   ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF CALIFORNIA HAS BEEN
   ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   
   THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
   INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
   MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE
   PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF
   CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
   UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
   
   stteki metin klasik ak-kod lisans olan BSD lisansdr. Kaynak
   kodun nasl kullanlabileceine dair snrlamalar yoktur. Bu lisans
   seviyoruz. Deitirme niyetimiz bulunmamaktadr.
   
    1.3) PostgreSQL, hangi Unix platforlarnda alr?
    
   Genel olarak, modern bir Unix-uyumlu platform PostgreSQL'i
   altracaktr. Ayrntl bilgi iin kurulum belgelerine
   bakabilirsiniz.
   
    1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
    
   PostgreSQL 8.0 srm ile , PostgreSQL artk Win2000, WinXP ve Win2003
   gibi Microsoft Windows NT tabanl iletim sistemlerinde doal olarak
   almaya balamtr. Paketlenmi bir kurulum program,
   http://pgfoundry.org/projects/pginstaller. adresinden indirilebilir.
   
   Ayrca, http://forge.novell.com adresinde Novell Netware 6 portu
   bulunmaktadr.
   
    1.5) PostgreSQL'i nereden indirebilirim?
    
   PostgreSQL iin ana anonim ftp sitesi ftp://ftp.PostgreSQL.org/pub
   adresidir. Yanslar iin, ana web sayfamza bakabilirsiniz.
   
    1.6) Nereden destek alabilirim?
    
   Ana e-posta listesi : pgsql-general@@PostgreSQL.org. PostgreSQL
   konusundaki tartmalara aktr. ye olmak iin, aadaki satrlar
   e-postanzn body ksmna (konu ksmna deil) yazp,
   pgsql-general-request@@PostgreSQL.org adresine gnderin:
d152 3
a154 3
   Ayn zamanda, bir digest listesi bulunmaktadr. Bu listeye ye olmak
   iin, pgsql-general-digest-request@@PostgreSQL.org adresine, body
   ksmnda
d158 7
a164 7
   yazan bir e-posta atmanz yeterli olacaktr.
   
   Digest postalar, ana liste 30k civarnda e-postaya ulatnda yelere
   gnderilmektedir.
   
   Bug'lar iin bir e-posta listesi bulunmaktadr. Bu listeye ye olmak
   iin, pgsql-bugs-request@@PostgreSQL.org adresine, body ksmnda
d168 5
a172 5
   yazan bir e-posta atmanz yeterli olacaktr.
   
   Ayn zamanda, gelitiriciler iin tartma listesi bulunmaktadr. Bu
   listeye ye olmak iin, pgsql-hackers-request@@PostgreSQL.org adresine,
   body ksmnda
d176 221
a396 322
   yazan bir e-posta atmanz yeterli olacaktr.
   
   Bunun dndaki e-posta listelerine ve PostgreSQL hakknda bilgiye,
   PostgreSQL WWW ana sayfasndan ulasabilirsiniz:
   http://www.PostgreSQL.org
   
   Ayn zamanda, EFNet zerinde, #PostgreSQL adl bir IRC kanal
   bulunmaktadr. Bunun iin, irc -c '#PostgreSQL' "$USER"
   irc.phoenix.net Unix komutunu kullanabilirsiniz.
   
   Ticari destek veren firmalarn listesine
   
   http://www.postgresql.org/users-lounge/commercial-support.html
   
   adresinden ulabilirsiniz.
   
    1.7) En son srm nedir?
    
   PostgreSQL'in son srm 7.4.6'dr.
   
   Her 6-8 ayda ana srm karlmas planlanmaktadr.
   
    1.8) Hangi belgelere ulaabilirim?
    
   Datmn iinde, kitapklar, kitapk sayfalar ve baz kk
   rnekler verilmektedir. /doc dizinine baknz. Ayrca, bu el
   kitapklarn online olarak http://www.PostgreSQL.org/docs/
   adresinden inceleyebilirsiniz.
   
   http://www.PostgreSQL.org/docs/awbook.html ve
   http://www.commandprompt.com/ppbook adreslerinde PostgreSQL kitaplar
   bulunmaktadr. PostgreSQL kitablarnn listesine,
   http://www.ca.PostgreSQL.org/books/ adresinden ulaaiblirsiniz.
   Ayrca, PostgreSQL konusundaki teknik makalelere de
   http://techdocs.PostgreSQL.org/ adresinden ulaabilirsiniz.
   
   psql'in, \d ile baslayan veri tipler, operatorler, fonksiyonlar,
   aggregate'ler, vb. ile ilgili gzel komutlar vardr.
   
   Web sitemiz daha fazla belgeyi iermektedir.
   
    1.9) Bilinen hatalar ya da eksik zelliklere nereden ulaabilirim?
    
   PostgreSQL SQL-92 uyumluluu iindedir, standartlardan fazla da
   zellikleri bulunmaktadr. Bilinen hatalar, eksik zellikler ve
   gelecek ile ilgili planlar iin TODO listesine baknz.
   
    1.10) Nasl SQL renebilirim?
    
   http:/www.PostgreSQL.org/docs/awbook.html adresindeki kitap SQL
   gretecektir. http://www.commandprompt.com/ppbook adresinde de bir
   baska PostgreSQL kitab bulunmaktadr.
   
   http://www.intermedia.net/support/sql/sqltut.shtm,
   http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM
   http://sqlcourse.com ve http://sqlcourse2.com adreslerinde de gzel
   belgeler bulunmaktadr.
   
   Bir bakas da, http://members.tripod.com/er4ebus/sql/index.htm
   adresinde bulunan "Teach Yourself SQL in 21 Days, Second Edition"
   kitabdr.
   
   Baz kullanclarmz da u kitab nermektedirler: "The Practical SQL
   Handbook, Bowman, Judith S., et al.,Addison-Wesley". Bazlar ise "The
   Complete Reference SQL, Groff et al., McGraw-Hill" kitabn
   nermektedirler.
   
    1.11) PostgreSQL 2000 ylna uyumlu mudur?
    
   Evet.
   
    1.12) Gelitirme takmna nasl katlabilirim?
    
   ncelikle, en son kaynak kodunu indirin ve web sitemizdeki ya da
   datmn iindeki PostgreSQL Developer belgesini okuyun. Ardndan,
   pgsql-hackers ve pgsql-patches listelerine ye olun. nc olarak da,
   pgsql-pacthes listesine yksek kalitede yamalar gnderin.
   
   PostgreSQL CVS arivine eriim izni olan, 10 kadar gelitirici
   bulunmaktadr. Hepsi defalarca, dier kiilerin yaptndan ok daha
   yksek-kaliteli yamalar gndermilerdir. Ayrca biz de bu
   gelitiricilerin ekledikleri yamalarn yksek kalitede olduuna
   gveniyoruz.
   
    1.13) Bir hata raporunu nasl gnderebilirim?
    
   PostgreSQL BugTool sayfasna gidiniz. O sayfada bir bug bildirmek iin
   neleri yapmanz gerektii anlatlmtr.
   
   Ayrca, ftp://ftp.PostgreSQL.org/pub ftp adresimizde, yeni bir
   PostgreSQL srm ya da yamas olup olmadni kontrol ediniz.
   
    1.14) PostgreSQL, diger DBMS'lerle nasl karlastrlabilir?
    
   Bir yazlmn gcn lmek iin eitli yollar vardr: Yazlmn
   zellikleri, baarm, gvenilirlii, destei ve creti.
   
   zellikler:
   
   PostgreSQL mevcut byk ticari veritabanlarnn, transaction,
   subselect, trigger, view, foreign key referential integrity ve
   sophisticated locking gibi (user-defined types), rules, inheritance ve
   lock cakmalarn drmek iin multi-version uyumluluk zellikleri
   bulunmaktadr.
   
   Performans (Baarm):
   
   PostgreSQL, dier ticari ve ak kaynak kodlu veritabanlaryla yakn
   baarm salar. Baz alardan daha hzldr, dier alardan da
   yavatr. MySQL ya da daha zayf veritabanlar ile
   karlatrldnda, INSERT/UPDATE ilemlerinde, transaction bazl
   alstmz iin daha yavaz. MySQL, yukardaki "zellikler"
   ksmnda belirtilenlerden hi birine sahip deildir. Biz, baarmmz
   her srmde arttrsak da, esneklik ve gelimi zellikler iin
   yaplanm durumdayz. PostgreSQL'i MySQL ile karlatran u web
   sitesine bakabilirsiniz: http://openacs.org/why-not-mysql.html
   
   Gvenilirlik:
   
   DBMS'lerin gvenilir olmas gerketii, yoksa deerleri olmayacan
   dnyoruz. ok iyi test edilmi, dengeli alsan minimum sayda hata
   ieren kod sunmaya alyoruz. Her bir srm en az 1 aylk beta
   testlerinden geirilmektedir. Srm gemiine bakarsanz, retime
   hazr, dengeli ve kararl kodlar sunduumuzu grebilirsiniz. Bu
   alanda, dier veritaban yazlmlarna stnlmz olduuna
   inanmaktayz.
   
   Destek:
   
   E-posta listemiz, oluan herhangi bir sorunu zebilecek byk sayda
   kullanc ve gelitirici grubunu ierir. Sorununuz iin, en az bir
   ticari veritaban kadar rahat zm bulabilirsiniz. Gelistiricilere,
   kullanc grubuna, belgelere ve kaynak koda direk olarak eriebilme,
   PostgreSQL desteini, dier DBMS'lere gre daha nemli klar.
   Gereksinimi olanlara, ticari destek verilebilir. (Destek iin 1.6
   blmne baknz.)
   
   Fiyat:
   
   Ticari ve ticari olmayan tm kullanmlarnz iin PostgreSQL
   cretsizdir. Kodumuzu, yukarda belirtilen BSD-stili lisanstaki
   snrlamalar hari, rnnzn iine ekleyebilirsiniz.
   
    1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
    
   PostgreSQL, 1996 ylndan beri 1. snf altyapya sahiptir. Bunun
   iin, yllar boyu alp bu altyapy oluturup yneten Marc
   Fournier'e teekkrler.
   
   Bir ak kaynak kodlu proje iin, kaliteli altyap ok nemlidir. Bu
   altyap, projenin kesilmesini nler ve projenin ilerlemesini
   hzlandrr.
   
   Tabii ki bu altyap ucuz deildir. lerin yrmesi iin eitli ylk
   ve anlk harcamalarmz olmaktadr. Eer siz ya da irketinizin bu
   abamza bata bulunabilecek paras varsa, ltfen
   http://store.pgsql.com/ adresine gidiniz ve bata, hibede bulununuz.
   
   Web sayfasnn 'PostgreSQL Inc.' den bahsetmesine ramen, "katkda
   bulunanlar" (contributors) maddesi sadece PostgreSQL projesini
   desteklemek iindir ve belirli bir irketin para kayna deildir.
   isterseniz, balant adresine bir ek gnderebilirsiniz.
     _________________________________________________________________
   
                         Kullanc/stemci Sorular
                                      
    2.1) PostgreSQL icin ODBC srcleri var m?
    
   iki tane ODBC srcs bulunmaktadr: PsqlODBC ve OpenLink ODBC.
   
   PsqlODBC'i
   http://gborg.postgresql.org/project/psqlodbc/projdisplay.php
   adresinden indirebilirsiniz.
   
   OpenLink ODBC http://www.openlinksw.com adresinden alnabilir.Bu
   src, kendi standart ODBC istemci yazlm ile alstndan,
   destekledikleri her platformda (Win, Mac, Unix, VMS) PostgreSQL ODBC
   bulunmalidir.
   
   cretsiz srm olmakla beraber, ticari kalitede destek almak
   isteyenlere satmak isteyeceklerdir. Sorularnz ltfen
   postgres95@@openlink.co.uk adresine gnderiniz.
   
    2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar
    bulunmaktadr?
    
   http://www.webreview.com/ adresinde, arka planda veritaban alstran
   Web sayfalar iin giri seviyesinde bilgi bulunmaktadr.
   
   Web ile btnleme iin, PHP () mkemmel bir arabirim sunar.
   
   Karmak sorunlar iin, ou kisi Perl arabirimini ve CGI.pm ya da
   mod_perl kullanr.
   
    2.3) PostgreSQL'in grafik kullanc arabirimi var mdr?
    
   eitli grafik arabirimlerimiz bulunmaktadr. Bunlarn arasnda,
   PgAccess (http://www.pgaccess.org/), PgAdmin II
   (http://www.pgadmin.org/, sadece Win32 iin), RHDB Admin
   (http://sources.redhat.com/rhdb/) ve Rekall
   (http://www.thekompany.com/products/rekall/) bulunmaktadr. Ayrca,
   PostgreSQL iin web tabanl bir arabirim olan PHPPgAdmin
   (http://phppgadmin.sourceforge.net/) bulunmaktadr.
   
   Daha ayrntl liste iin
   http://techdocs.postgresql.org/guides/GUITools adresine
   bakabilirsiniz.
   
    2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri kullanabilirim?
    
     * C (libpq)
     * Embedded C (ecpg)
     * Java (jdbc)
     * Python (PyGreSQL)
     * TCL (libpgtcl)
       
   Dierleri iin, http://gborg.postgresql.org adresindeki
   Drivers/Interfaces blmne bakabilirsiniz.
     _________________________________________________________________
   
                             Ynetimsel Sorular
                                      
    3.1) PostgreSQL'i, /usr/local/pgsql dizininden baka dizinlere nasl
    kurabilirim?
    
   configure betiini alstrrken, --prefix seeneini veriniz.
   
    3.2) postmaster'i baslattgmda, a Bad System Call ya da core dumped mesaj
    alyorum. Neden?
    
   Bunun birok nedeni olabilir. Ancak ilk kontrol edilmesi gereken sey,
   ekirdeginize System V uzantlarnn kurulu olup olmadgn kontrol
   etmek olabilir. PostgreSQL shared memory ve semaphores iin ekirdek
   destegine gereksinim duyar.
   
    3.3) postmaster'i balattmda, pcMemoryCreate hatas alyorum. Neden?
    
   Ya ekirdeinizde shared memory desteiniz dzgnce
   yaplandrlmamtr, ya da ekirdeinizdeki mevcut shared memory
   miktarn bytmeniz gerekecektir. Gereksinim duyacanz miktar,
   mimarinize ve postmaster iin ayarladgnz tampon ile backend ilemi
   saysna baldr. Tm sistemler iin, tamponlar ve ilemlerde
   ntanml saylarla, ~ 1MB kadar yere gereksinmeniz olacaktr.
   PostgreSQL 7.3.2 Sistem Yneticileri Rehberi'ne, shared memory ve
   semaphorelar hakkndaki ayrntl bilgi iin bakabilirsiniz.
   
    3.4) postmaster' balattmda, pcSemaphoreCreate hatas alyorum. Neden?
    
   Eer hata, "pcSemaphoreCreate: semget failed (No space left on
   device)" ise, ekirdeiniz yeterli semaphore ile yaplandrlmam
   demektir. Postgres, her bir potansiyel backend iin bir semaphore
   gereksinimi duyar. Geici bir zm, postmaster backend ilemleri
   iin daha az miktarda snrla balatmak olabilir. -N'i varsaylan
   deer olan 32'den kk bir deerle balatnz. Daha kalc bir zm,
   ekirdeinizin SEMMNS ve SEMMNI parametrelerini ykseltmek olacaktr.
   
   almayan semaphore'lar ar veritaban ilemlerinde kme
   yaratabilirler.
   
   Eer hata mesajnz baka bir ey ise, ekirdeinizde semaphore
   desteini yaplandrmam olabilirsiniz. Shared memory ve
   semaphore'lar hakkndaki daha ayrntl bilgi iin PostgreSQL 7.3.2
   Sistem Yneticileri Rehberi'ne bakabilirsiniz.
   
    3.5) Diger bilgisayarlarn benim PostgreSQL veritaban sunucuma
    balantlarn nasl kontrol edebilirim?
    
   n tanml olarak, PostgreSQL sadece yerel makineden Unix domain
   sockets kullanarak balanlmasna izin verir. Diger makineler,
   postmaster'a -i etiketini geirmezseniz ve $PGDATA/pg_hba.conf
   dosyasn dzenleyerek host-based authentication'a olanak vermezseniz,
   balant yapamayacaklardr.
   
    3.6) Veritabani motorunu daha iyi baarm iin nasl ayarlayabilirim?
    
   Index'ler sorgular hzlandrabilir. EXPLAIN komutu, PostgreSQL'in
   sorgunuzu nasl yorumladn ve hangi index'leri kullandn
   grmenize izin verir.
   
   Eer cok fazla INSERT ilemi yapyorsanz, bunlar byk bir toplu
   ilem dosyaskullanp COPY komutu ile veritabanna girmeyi deneyiniz.
   Bu, tekil INSERT'lerden daha hzldr. kinci olarak, BEGIN
   WORK/COMMIT transaction blou iinde olmayan ifadeler kendi
   transaction'larndaym gibi dnlr. oklu ifadeleri tek bir
   transaction blou iinde yapabilirsiniz. Bu, transaction overhead'ini
   drecektir. Tek bir transaction blou iinde birden ok ifadeyi
   altrmay deneyebilirsiniz. Bu da ayn ekilde, transaction
   overhead'ini drr.
   
   eitli ayarlama seenekleri mevcuttur. fsync() ilemini, postmaster'
   -o -F seenei ile balatarak devre d brakabilirsiniz. Bu ilem,
   fsync()'lerin her transactiondan sonra diski flush etmesini
   engelleyecektir.
   
   Ayn zamanda, postmaster'i -B seenei ile balatp, backend ilemleri
   tarafndan kullanlan shared memory buffers saylarn
   arttrabilirsiniz. Eer bu parametreyi ok yksek tutarsanz,
   ekirdeinizin shared memory blgesindeki limiti ama olaslnz
   yznden postmaster balayamayabilir. Her bir tampon (buffer) 8K'dr.
   ntanml say ise 64 tampondur.
   
   Ayn ekilde, backend'in -S seeneini geici sralamalar iin backend
   sreleri tarafndan kullanlacak hafzay arttrmak amacyla
   kullanabilirsiniz. -S seenei kilobayt cinsinden deer alr ve n
   tanml deeri 512'dir (512 K)
   
   Tablolardaki veriyi bir index'e elemek amacyla gruplama iin CLUSTER
   komutunu kullanabilirsiniz. Ayrntl bilgi iin CLUSTER komutunun
   yardm sayfasna bakabilirsiniz.
   
    3.7) Hangi hata ayklama zellikleri bulunmaktadr?
    
   PostgreSQL, hata ayklama amacyla kullanlabilecek durum bilgisi
   rapor eden eitli zeliklere sahiptir.
   
   ncelikle, configure betiini --enable-cassert seeneiyle
   altrrsanz, bir ok assert() backend calmasn gzlemler ve
   beklenmeyen bir durumda program durdurur.
   
   Postmaster ve postgres eitli hata ayklama seeneklerine sahiptir.
   ncelikle, postmaster' balattnzda, standart kty ve hatalar
   bir log dosyasna ynlendirdiinize emin olun:
d400 78
a477 124
   Bu ilem PostgreSQL ana dizinine server.log dosyas yerletirecektir.
   Bu dosya sunucunun yaad sorunlar ya da hatalar hakknda yararl
   bilgiler ierir. -d seenei, hata ayklama seviyesini belirten bir
   rakam ile kullanlr. Yksek hata ayklama seviyelerinin byk log
   dosyalar oluturacan unutmaynz.
   
   Eer postmaster almyorsa, postgres backend'ini komut satrndan
   altrabilir ve SQL ifadenizi direk olarak yazabilirsiniz. Bu sadece
   hata ayklama amacyla nerilir. Burada, noktal virgln deil de
   yeni bir satrn sorguyu sonlandrdn unutmaynz. Eer hata
   ayklama sembolleri ile derlediyseniz, ne olduunu grmek iin bir
   hata ayklayc kullanabilirsiniz. backend postmaster'dan
   balatlmadndan, edeer bir ortamda almamaktadr ve
   locking/backend etkileim sorunlar artabilir.
   
   Eer postmaster alyorsa, bir pencerede psql'i altrn ve psql
   tarafndan kullanlan postgres srecinin sre numarasn (PID) bulun.
   Postgres sreci ile ilikilendirmek iin bir hata ayklarc kullann.
   Sorgular psql aracl ile altrabilirsiniz. Eer postgres
   balangcnda hata ayklamak istiyorsanz, PGOPTIONS="-W n" seeneini
   ayarlayabilir ve psql'i balatabilirsiniz. Bu ilem, balangcn n
   saniye kadar gecikmesini salayacaktr; bylece hata ayklaycy
   srece ilikilendirdikten sonra balang srecinin devam etmesini
   salayabilirsiniz.
   
   postgres program hata ayklama ve baarm lmleri iin -s, -A ve -t
   seeneklerine sahiptir.
   
    3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn
    alyorum?
    
   Postmaster'n ezamanl olarak balatabilecei backend sreleri
   snrlarn arttrmanz gerekmektedir.
   
   n tanml deer 32 sretir. Bunu, postmaster' uygun -N deeri ile
   ya da postgresql.conf dosyasn dzenleyerek yeniden balatmakla
   arttrabilirsiniz.
   
   Eer -N deerini 32'den byk yapacaksanz, ayn zamanda -B deerini
   de deitirmeniz gerektiini unutmayn. -B, -N'nin en az 2 kat kadar
   olmaldr; daha iyi baarm iin bu sayy daha da arttrmalsnz.
   Yksek saydaki backend sreleri iin, eitli ekirdek yaplandrma
   parametrelerini arttrmanz gerekecektir. Yaplmas gerekenler,
   SHMMAX, SEMMNS, SEMMNI, NPROC, MAXUPRC ve alabilecek dosyalarn
   maksimum says olan NFILE ve NINODE deerlerini kartrmaktr. Bunun
   nedeni, PostgreSQL'in izin verilen backend srelerinin says
   zerinde bir snr olmasdr. Bylelikle sistem kaynaklarnn dna
   klmayacaktr.
   
   PostgreSQL'in 6.5 srmne kadar, en fazla backend says 64 idi ve
   bunu deitirmek iin include/storage/sinvaladt.h dosyas iindeki
   MaxBAckendid sabitini deitirdek sonra yazlm yeniden derlemek
   gerekiyordu.
   
    3.9) pgsql_tmp dizinin iindeki dosyalar nelerdir?
    
   Sorgu alstrc (query executer) tarafndan yaratlan geici
   dosyalardr. rnegin, bir sralama ORDER BY ile yaplacaksa ve
   sralama backend'in -s parametresinin izin verdiinden daha fazla
   alana gereksinim duyuyorsa, ekstra veriyi tutmak iin geici dosyalar
   yaratlr.
   
   Geici dosyalar, eer sralama srasnda backend gmezse otomatik
   olarak silinecektir. Eer alan durumda bir backend'iniz yoksa,
   pg_tempNNN.NN dosyalarn silmeniz gvenlidir.
   
    3.10) PostgreSQL srmlerini ykseltmek iin neden bir dump/reload ilemi
    gerekletirmek zorundaym?
    
   PostgreSQL takm ara srmlerde sadece kk deiiklikler
   yapmaktadr; bu yzden 7.2 srmnden 7.2.1'e ykseltmek dump/restore
   ilemi gerekmemektedir. Ancak, esas srmlerde (rnek: 7.2'den 7.3'e)
   ounlukla sistem tablolarnn ve veri dosyalarnn i yaps
   deitirilir. Bu deiiklikler ounlukla karmaktr; dolaysyla
   veri dosyalarnn geriye dnk uyumluluu ilemlerini yapmyoruz. Dump
   ilemi, veriyi genel biimde alacandan yeniden ykleme esnasnda
   veri, yeni i biime uygun ekilde yerletirilecektir.
   
   Disk biiminin deimedii srmlerde, pg_upgrade betii gncellemenin
   bir dump/restore gerektirmeden yaplmasn salayacaktr. pg_upgrade
   betiinin o srm iin bulunup bulunmadn srm notlar iinde
   bulabilirsiniz.
   
    3.11) Nasl bir donanm kullanmalym?
    
   PC donanm tamamen uyumlu olduu iin, insanlar tm PC donanmlarnn
   ayn kalitede olduunu dnrler. Oysa byle deildir. ECC RAM, SCSI
   ve kaliteli anakartlar daha ucuz donanmlara gre daha ok
   gvenilirlerdir ve baarmlar daha yksektir. PostgreSQL hemen hemen
   tm donanmda alabilmektedir, ancak gvenilirlik ve baarm nemli
   ise donanm seeneklerini ok iyi aratrmak gereklidir. E-posta
   listelerimi donanmlarla ilgili sorular ve de ticaret iin
   kullanlabilir.
     _________________________________________________________________
   
                             letimsel Sorular
                                      
    4.1) Binary cursor ve normal cursor arasndaki fark nedir?
    
   DECLARE yardm sayfasna baknz.
   
    4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
    
   FETCH yardm sayfasna baknz, ya da SELECT ... LIMIT ... kullannz.
   
   lk birka satr almak isteseniz bile, tm sorgu deerlendirilmek
   durumunda kalnabilir. ORDER BY ieren bir sorgu dnn. Eer ORDER
   BY ie eleen bir index varsa, PostgreSQL istenen ilk birka satr
   ileyebilir, ya da tm sorgu istenen satrlar retilene kadar
   ilenebilir.
   
    4.3) psql'in iinde grdgm tablolarn ya da dier eylerin listesini
    nasl alabilirim?
    
   pgsql/src/bin/psql/describe.c iindeki psql kaynak kodunu
   okuyabilirsiniz. Bu kod, psql'in \ ile balayan komutlarnn ktsn
   olusturan SQL komutlarn ierir. Ayn zamanda, psql'i -E seenei ile
   balatp, verdiiniz komutlar altrmak iin yapt sorgularn
   ktlarn grebilirsiniz.
   
    4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
    
   Bu zellik (ALTER TABLE DROP COLUMN) 7.3 srm ile gelmitir. Eski
   srmlerde aadakileri uygulamalsnz:
d485 45
a529 44
COMMIT;
                
    4.5) Bir satr, tablo ve veritaban iin en fazla byklk nedir?
    
   Snrlar:
   
   Veritaban iin en fazla byklk nedir?
   Snrsz (32 TB'lk veritaban bulunmaktadr)
   Bir tablo iin en fazla byklk nedir?
   32 TB
   Bir satr iin en fazla byklk nedir?
   1.6 TB
   Bir alan iin en fazla byklk nedir?
   1 GB
   Tabloda en fazla satr says katr?
   Snrsz
   Bir tabloda olabilecek en fazla kolon says katr?
   Kolon tiplerine bal olarak 250-1600
   Bir tabloda olabilecek en fazla index says katr?
   Snrsz
   
   Tabii ki bunlar aslnda snrsz degildir. Burada belirtilen snrlar,
   fiziksel snrlarn haricindeki snrlardr. Bo disk alan,
   hafza/takas alan na bal snrlamalar vardr. Baarm, snr
   deerlere yaklatka, ya da deerler ok byk olduunda debilir.
   
   Bir tablo iin byklk snr olan 32 TB, iletim sisteminin byk
   dosya destei olup olmamasndan bamszdr. Byk tablolar, 1 GB'lik
   dosyalarda sakland iin, dosya sistemi snrlarnin bir nemi
   yoktur.
   
   Tablo ve kolon says byklkleri, n tanml blok bykl 32k ya
   karlarak arttrlabilir.
   
    4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk alan
    gereklidir?
    
   Bir PostgreSQL veritaban, veriyi "flat" metin dosyasnda saklamak
   iin gereken alann 5 kat fazla disk alanna gereksinim duyabilir.
   
   Her satrnda bir tamsay ve metin (text) ieren, 100.000 satrlk bir
   dosya dnn. Her satrn ortalama 20 byte olduunu farzedelim. Metin
   dosyas 2.8 MB olacaktr. Bu veriyi tutan PostgreSQL veritaban
   yaklak 6.4 MB yer kaplayacaktr.
d531 1
a531 1
+ 24 byte: Bir tamsay (int) alan ve bir metin (text) alan
d536 2
a537 2
   PostgreSQL'de veri sayfas (data page) bykl 8192 byte (8k)dr,
   dolaysyla:
d541 1
a541 1

d546 32
a577 48
   782 veritaban sayfas * sayfa bana 8192 byte = 6,406,144 bytes (6.4
   MB)
   
   Index'ler ok fazla yere gereksinim duymazlar, ama index'lenmi veriyi
   tutacaklarndan byk olabilirler.
   
   NULL deerler bitmapler iinde tutulur; dolaysyla ok az yer
   kaplarlar.
   
    4.7) Veritabannda hangi tablo ya da index'lerin tanmlandn nasl
    grebilirim?
    
   psql, bu tr bilgileri gstermek iin, \ ile balayan bir ok komut
   sunmaktadr. \? komutu ile bu komutlar grebilirsiniz. Ayrca,
   bunlar aklayan ve pg_ ile balayan ok sayda sistem tablosu
   bulunmaktadr. Ayn zamanda, psql -l ile tm veritabanlarn
   listeyelebirsiniz.
   
   Ayrca, pgsql/src/tutorial/syscat.source kodunu inceleyebilirsiniz. Bu
   dosya, veritaban sistem dosyalarndan bilgiyi almak iin gereksinim
   duyulan bir ok SELECT'leri gsterir.
   
    4.8) Sorgularm cok yava, ya da index'lerimi kullanmyorlar. Neden?
    
   Indexler her sorgu tarafndan otomatik olarak kullanlmazlar. Indexler
   eer bir tablonun bykl minimum bir byklkten fazla ise ve sorgu
   tablodaki satrlarn sadece kk bir yzdesini seiyorsa kullanlr.
   Bunun nedeni, index eriiminin neden olduu raslansal disk eriimi nin
   diskin ya da tablonun sral okunmasndan daha yavas olabilmesidir.
   
   Bir index'in kullanlp kullanlmayacan belirlemek iin, PostgreSQL
   tablo hakkndaki istatistiklere gereksinmesi vardr. Bu istatistikler,
   VACUUM ANALYZE kullanlarak toplanrlar. Optimizer, istatistikleri
   kullanarak, tabloda ka satr olduunu ve bilir ve indexin kullanlp
   kullanlmayacana daha iyi karar verir. Istatistikler, ayn zamanda
   en uygun join srasn ve yntemini belirlemekte ok nemlidir.
   statistik toplanmas, tablo ierikleri deitike periyodik olarak
   yaplmaldr.
   
   Indexler normalde ORDER BY sorgular ya da join ilemlerini
   gerekletirmek iin kullanlmazlar. Ak bir sralamay takip eden
   sral bir arama (sequential scan), byk bir tabloda index aramas
   yapmaktan genelde daha hzldr.
   Ancak, ORDER BY ile birlemi LIMIT genellikle bir index
   kullanacaktr; nk tablonun sadece belirli bir miktar
   dndrlecektir. Aslnda, MAX() ve MIN() fonksiyonlarnn index
   kullanmamalarndan dolay, bu gibi deerleri ORDER BY ve LIMIT
   kullanarak da almak olasdr:
d583 43
a625 59
   Eer optimizer'n sral arama yapmasnn yanl olduuna
   inanyorsanz, SET enable_seqscan TO 'off' kullann ve index kullanan
   aramalarn hala daha hzl olup olmadn grn.
   
   LIKE ya da ~ gibi operatrler kullanyorsanz, index'ler sadece
   aadaki koullarda kullanlabilir:
     * Arama dizininin ba, dizinin ba ile balanmaldr. Yani,
          + LIKE sorgular % ile balamamaldr.
          + Dzenli ifade sorgular ^ ie balamamaldr.
     * Arama metni bir karakter snf ile balayamaz. rnek: [a-e]
     * ILIKE ve ~* gibi byk/kk harfe duyarsz aramalar index'lerden
       yararlanmazlar. Onun yerine, blm 4.12'de anlatlan fonksiyonel
       index'leri kullanabilirsiniz.
     * initdb srasnda ntanml C locale'i kullanlmaldr.
       
    4.9) query-optimizer'n sorgularm nasl deerlendirdiini, ileme
    soktuunu nasl grebilirim?
    
   EXPLAIN yardm sayfasna baknz.
   
    4.10) R-tree index nedir?
    
   R-tree index, uzaysal (spatial) verileri indexlemek iin kullanlr.
   Bir hash index, dizi aramalarnda (range search) kullanlamaz. B-tree
   index dizi aramalarnda sadece tek boyutlu almaktadr. R-tree, ok
   boyutlu veriyi destekler. rnein, eer bir R-tree index point veri
   tipi zerinde ina edililebilirse, sistem "select all points within a
   bounding rectangle" gibi sorgulara daha verimli yantlar verecektir.
   
   Orijinal R-tree tasarmn aklayan belge:
   
   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.
   
   Bu belgeyi, Stonebraker'n "Readings in Database Systems" kitabnda
   bulabilirsiniz.
   
   Gml R-tree indexleri poligon ve boxlar kullanabilir. Teorik
   olarak, R-tree indexlerin zelliklerini geniletmek bir miktar aba
   gerektirir ve bunun nasl yaplacana dair bir belgemiz henz
   bulunmamaktadr.
   
    4.11) Genetic Query Optimizer nedir?
    
   GEQO modl, Genetic Algorithm(GA) kullanlarak tablolar
   birletirildiinde sorgu optimizasyonunu hzlandrr.
   
    4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe
    duyarsz aramalar nasl yapabilirim? Bu byk(kk harfe duyarl aramalar
    iin index'i nasl kullanabilirim?
    
   ~ operatr dzenli ifade elemesi ve ~* byk/kk harfe duyarsz
   dzenli ifade elemesi yapar. Byk/kk harfe duyarl olan LIKE'n
   byk/kk harfe duyarsz olan biimi ILIKE'tr ve PostgreSQL 7.1
   srm ile birlikte gelmitir.
   
   Byk-kk harfe duyarsz eitlik karlatrmalar aadaki gibi
   ifade edilir:
d629 4
a632 3
                
   Bu standart bir index yaratmayacaktr. Ancak eer fonksiyonel bir
   index yaratrsanz; o kullanlacaktr:
d635 6
a640 7
    4.13) Bir sorguda, bir alanin "NULL" olduunu nasl ortaya karabilirim?
    
   Kolonu, IS NULL ve IS NOT NULL ile test edebilirsiniz.
   
    4.14) esitli karakter tipleri arasndaki farklar nelerdir?
    
Veri Tipi            Ad              Not
d644 1
a644 1
TEXT            text            uzunlukta herhangi bir st snr yoktur.
d646 19
a664 27
"char"          char            bir karakter
                
    adlar (internal name) sistem kataloglarn ve baz hata
   mesajlarn incelerken greceksiniz.
   
   lk drt veri tipi "varlena" tipidir (yani, diskteki ilk 4 bayt
   uzunluktur; devam da veridir.) Dolaysyla, kullanlan gerek alan,
   belirtilen alandan biraz daha byktr. Ancak, bu veri tipleri,
   sktrlmaya tabi tutulabilir; dolaysyla disk alan beklenilenden
   kk olabilir. VARCHAR(n) bykl artabilen ama en byk uzunluu
   snrl olan verileri saklamak iin en uygun yntemdir. TEXT, 1 GB
   bykle kadar olan verileri tutmak iin kullanlr.
   
   CHAR(n), ayn uzunluktaki dizilerin saklanmas iin kullanmr.
   CHAR(n) belirtilen uzunlua kadar boluk ile doldurur; ancak
   VARCHAR(n) sadece verilen karakterleri saklar. BYTEA binary veri
   saklamak iindir; ayrca "NULL" bayt ieren deerleri de saklar.
   Burada anlatlan  veri tipi de benzer baarm karakteristiklere
   sahiptir.
   
    4.15.1) Nasl serial/otomatik artan (auto-incrementing) bir alan
    yaratabilirim?
    
   PostgreSQL'de SERIAL veri tipi vardr. Bu veri tipi bir sequence ve
   kolon zerinde bir index yaratr.
   
   rnek, aadaki sorgu:
d668 5
a672 3
);
                
   buna evrilir:
d678 11
a688 14
CREATE UNIQUE INDEX person_id_key ON person ( id );
                
   Sequenceler hakknda daha fazla bilgi iin create_sequence yardm
   sayfasna bakabilirsiniz. Her satrn OID alann tekil bir say
   olarak alabilirsiniz. Ancak, veritabannzn dump'n alp yeniden
   yklerseniz, OID deerlerini koruyabilmek iin pg_dump'n -o
   parametresini ya da "COPY WITH OIDS" seeneini kullanmanz
   gerekecektir.
   
    4.15.2) SERIAL giriinin degerini nasl alabilirim?
    
   Bir yaklam, sequence nesnesindeki SERIAL deerini, veriyi girmeden
   nce nextval() ile alp, aldnz deeri kendinizin girmesidir.
   4.15.1'deki rnek tabloyu kullanarak bir rnek verelim:
d693 68
a760 88
   Dier sorgular iin new_id'de yeni deerin saklanmas gerekir.
   Otomatik olarak yaratlan SEQUENE nesnesinin ad, <tablo ad>_<serial
   kolonu ad>_seq eklinde olacaktr (< > iaretleri olmadan).
   
   Alternatif olarak, atanm SERIAL deerini, deer girildikten sonra
   currval() fonksiyonu ile alabilirsiniz:
                execute("INSERT INTO person (name) VALUES ('Blaise Pascal')");
                new_id = execute("SELECT currval('person_id_seq')");
                
   Son olarak, n tanml deeri bulmak iin INSERT ifadesinden dnen OID
   deerini kullanabilirsiniz; ancak bu en az tanabilir zm
   olacaktr. Perl'de, Edmund Mergl'in DBD:Pg mdl ile birlikte DBI
   kullanarak, OID deeri $sth->execute() altrldktan sonra
   $sth->(pg_oid_status) ile alnabilir.
   
    4.15.3) currval() ve nextval() dier kullanclara sorun yaratmaz m?
    
   Hayr. curval(), tm kullanclar deil, backend tarafndan atanan
   geerli deeri dndrr.
   
    4.15.4) Neden sequence saylar transaction ileminin iptalinden sonra
    yeniden kullanlyor? Neden sequence/SERIAL kolonumdaki saylarda atlamalar
    oluyor?
    
   Uyumluluu arttrmak iin, sequence deerleri alan transaction'lara
   gerektii ekilde aktarlr ve transaction bitene kadar o deer
   kilitlenmez. Bu, iptal edilen transaction ilemleri nedeniyle
   boluklara neden olur.
   
    4.16) OID nedir? TID nedir?
    
   OIDler, tekil satr numaralarna PostgreSQL'in yantdr.
   PostgreSQL'de yaratlan her say, tekil bir OID alr. initdb ilemi
   srasnda yaratlan tm OID'ler 16384'ten kktr
   (backend/access/transam.h). Kullanclar tarafndan yaratlan tm
   OID'ler bu sayya eit ya da bu saydan byktr. Varsaylan durumda,
   tm bu OIDler sadece bir tablo ya da veritabannda deil, tm
   PostgreSQL kurulumunda tekildir.
   
   PostgreSQL OIDleri, tablolar arasnda satrlar ilikilendirmek iin
   kendi i tablolarnda kullanr. Bu OIDler belirli kullanc
   satrlarn belirtmek iin kullanabilir ve join ilemlerinde
   kullanlr. OID deerlerini saklamak iin OID kolon tipini kullanmanz
   nerinir. Daha hzl bir eriim iin, OID alannda bir index
   yaratabilirsiniz.
   
   OID'ler yeni satrlara, tm veritabanlar tarafnda kullanlan ortak
   bir alandan atanrlar. Eer OID'i baka bir deere eitlemek
   isterseniz ya da tablonun bir kopyasn orijinal OIDler ile karmak
   isterseniz, bu mmkndr:
                        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';
                
   OIDler 4-bit tamsay olarak saklanrlar ve 4 milyarda overflow
   olacaktr. Kimse bu sayya ulatna dair bir bilgi iletmedi ve bu
   snr kimse bu snra ulamadan kaldracaz.
   
   TIDler, belirli fiziksel satrlar block ve offset deerleri ile
   belirtmekte kullanlr. TIDler, satrlar deitiinde ya da yeniden
   yklendiinde deiirler. Index girdileri tarafndan fiziksel
   satrlar gstermek iin kullanlrlar.
   
    4.17) PostgreSQL'de kullanlan baz terimlerin anlamlar nelerdir?
    
   Kaynak kodun bir ksm ve eski belgeler, daha geni kullanm alan
   olan terimleri kullanrlar. Bunlarn bazlar:
     * table, relation, class
     * row, record, tuple
     * column, field, attribute
     * retrieve, select
     * replace, update
     * append, insert
     * OID, serial value
     * portal, cursor
     * range variable, table name, table alias
       
   Genel veritaban terimleri,
   http://hea-www.harvard.edu/MST/simul/software/docs/pkgs/pgsql/glossary
   /glossary.html adresinde bulunabilir.
   
    4.18) Neden "ERROR: Memory exhausted in AllocSetAlloc()" hatasn alyorum?
    
   Sisteminizde sanal belleinizi tketmi olabilirsiniz, ya da
   ekirdeiniz belli kaynaklar icin dk bir snra sahip olabilir.
   postmaster' balatmadan nce aadakileri deneyebilirsiniz:
d762 25
a786 33
limit datasize 256m
                
   Kabuunuza bal olarak, bunlardan sadece biri olumlu sonu
   verecektir, ama bu ilem veri segment snrnz arttracak, ve belki
   de sorgunuzun tamamlanmasn salayacaktr. Bu komut, varolan ileme
   (current process) ve komut altrldktan sonraki tm alt ilemlere
   uygulanr. Eer SQL istemcinizle, backend'in ok fazla veri dndrmesi
   nedeniyle bir sorun yayorsanz, bunu istemciyi balatmadan nce
   deneyiniz.
   
    4.19) Hangi PostgreSQL srmn altrdm nasl grebilirim?
    
   psql arabiriminde, select version(); yaznz.
   
    4.20) Neden large-object ilemlerim, "invalid large obj descriptor"
    hatasn veriyor?
    
   Large object ilemlerinizin ularna, yani lo_open ... lo_close
   komutlarnn evresine, BEGIN WORK ve COMMIT koymanz gerekmektedir;
   
   u anda, PostgreSQL kurallar large objectleri transaction commit
   edildiinde kapatarak uygulamaktadr. Dolaysyla handle ile yaplacak
   ilk ey invalid large obj descriptor hatas ile
   sonulanacaktr.Dolaysyla alan kodunuz eer transaction
   kullanmazsanz hata mesajlar retecektir.
   
   Eer ODBC gibi bir istemci arabirimi kullanyorsanz, auto-commit'i
   kapatmanz gerekebilir.
   
    4.21) u andaki zaman ntanml deer olarak kabul eden How do I create a
    column that will default to the current time?
    
   Alttakini kullanabilirsiniz:
d789 7
a795 6
                
    4.22) Neden IN kullanan subquery'lerim ok yavas?
    
   7.4 srmnden nce, subqueryler. Eer subquery sadece birka satr ve
   outer query bol sayda satr dndryorsa, IN en hzlsdr. Sorgular
   hzlandrmak iin IN yerine EXISTS kullann:
d799 4
a802 2
                
   sorgusunu, aadaki ile deitirin:
d805 11
a815 12
    WHERE EXISTS (SELECT col2 FROM TAB2 WHERE col1 = col2)
                
   Bu ilemin hzl olmas iin, subcol'un indexlenmi bir kolon olmas
   gerekmektedir.
   
   7.4 srm ve sonrasnda, IN aslnda normal sorgularla ayn karmak
   join tekniklerini kullanr ve EXISTS'e tercih edilir.
   
    4.23) Outer join ilemini nasl yapabilirim?
    
   PostgreSQL outer joins islemlerini SQL standartlarn kullanarak
   gerekletirmektedir. Aada 2 rnek bulunmaktadr:
d817 5
a821 3
FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);
                
   ya da
d823 11
a833 13
FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col);
                
   Bu zde sorgular t1.col' i t2.col'ye join ederler ve ayn zamanda
   t1'deki unjoined satrlar (t2'de elenmemi olanlarla) dndrrler.
   RIGHT JOIN t2'nin unjoined satrlarn ekleyecektir. Bir FULL join,
   elemi btn satrlar ve t1 ile t2'den tm balanmam (unjoined)
   satrlar alr. OUTER szc seimseldir ve LEFT, RIGHT ve FULL join
   ilemlerinde olduu kabul edilir. Sradan join ilemleri INNER JOIN
   olarak adlandrlr.
   
   nceki srmlerde, OUTER JOINler UNION ve NOT IN kullanlarak simle
   edilebiliyordu. rnein, tab1 ve tab2'yi birletirirken, aadaki
   sorgu iki tablonun dtan balanmasn salar:
d841 57
a897 76
ORDER BY col1
                
    4.24) Ayn andan birden fazla veritabannda nasl ilem yapabilirim?
    
   Mevcut veritabannz dndaki baka bir veritabannz sorgulamanzn
   bir yolu bulunmamaktadr. Bunun nedeni, PostgreSQL'in veritabanna
   zel sistem kataloglar yklemesidir. Bu nedenle, cross-database bir
   sorgunun nasl davranacan kestirmek zordur.
   
   contrib/dblink fonksiyon arlarn kullanarak cross-database
   sorgulara izin verir. Tabii ki, bir istemci deiik veritabanlarna
   ayn anda eriim salayabilir ve bilgiyi bu ekilde birletirebilir.
   
    4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?
    
   7.3 srmnde, bir fonksiyondan kolaylkla oklu satr ya da stun
   dndrebilirsiniz.
   (http://techdocs.postgresql.org/guides/SetReturningFunctions)
   
    4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo
    yaratma/kaldrma ilemlerini yapamyoruz?
    
   PL/PgSQL fonksiyon ierikleri cache'ler. Bunun istenmeyen bir taraf,
   eer bir PL/PgSQL fonksiyonu geici bir tabloya eriiyorsa ve bu tablo
   ileride kaldrlp yeniden oluturulduktan sonra fonksiyon yeniden
   arlrsa, fonksiyon almayacaktr; nk cache'lenmi fonksiyon
   hala eski geici tabloyu gsteriyor olacaktr. zm, geici tablo
   eriimleri iin PL/PgSQL'de EXECUTE kullanmaktr. Bu, sorgunun her
   seferinde yeniden ilenmesini salayacaktr.
   
    4.27) 4.28) Hangi ifreleme seenekleri bulunmaktadr?
    
     * contrib/pgcrypto SQL sorgularnda kullanlabilmesi iin ifreleme
       fonksiyonlar iermektedir.
     * stemciden sunucuya iletiimi ifrelemek iin, sunucuda ssl
       seenei postgresql.conf iinde ak olmaldr. Ayrca,pg_hba.conf
       dosyas iinde host ya da hostssl kayd mutlaka olmaldr ve
       istemci sslmode kapatlmamaldr. (Ayn zamanda,PostgreSQL'in
       doal SSL balantlar dnda ssh ya da ssl gibi 3.parti
       ifrelenmi veri iletimi de mmkndr.)
     * Veritaban kullanc ad ve ifreleri 7.3 srm ile birlikte
       otomatik olarak ifrelenirler. nceki srmlerde, postgresql.conf
       iindeki PASSWORD_ENCRYPTION seeneini aktif hale getirmeniz
       gerekmektedir.
     * Sunucunun kendisini ifreli dosya sistemi zerinde
       altrabilirsiniz.
     _________________________________________________________________
   
                    PostgreSQL zelliklerini Geniletmek
                                      
    5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman
    neden core dump ediyor?
    
   Sorunun nedeni birden fazla ey olabilir. Kullanc-tanml
   fonksiyonunuzu stand-alone bir programda altrmay deneyiniz.
   
    5.2) PostgreSQL'e nasl yeni tipler/fonksiyonlar ekleyebilirim?
    
   almalarnz pgsql-hackers e-posta listesine gnderiniz. Kodunuz
   incelendikten sonra /contrib dizinine konacaktr.
   
    5.3) Bir tuple dondrmek icin bir C fonksiyonunu nasil yazarm?
    
   PostgreSQL 7.3 srm ile birlikte, C, PL/PgSQL ve SQL kullanlarak
   tablo-dndren fonksiyonlar tamamen desteklenmektedir. Ayrntl bilgi
   iin PostgreSQL 7.3.2 Kullanc Rehberi'ne bakabilrisiniz. Bir rnei
   contrib/tablefunc iinde bulabilirsiniz.
   
    5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen
    deiiklik geerli olmuyor. Neden?
    
   Makefile'lar include dosyalar iin tam bir bamllk iermezler.
   ncelikle make clean, ardndan da baska bir make ilemi yapmanz
   gerekir. GCC kullanyorsanz, configure betiinin --enable-depend
   seeneini, derleyicinin bamllklar otomatik olarak hesaplamas
   iin kullanabilirsiniz.
@


1.5
log
@Update Turkish FAQ.

Devrim GUNDUZ
@
text
@d3 1
a3 1
Son gncelleme : 09 Kasm 2004 Sal - 12:02:27
d8 1
a8 1
Nicholas Morris Tufar (ntufar@@tdmsoft.com)
d80 1
a80 2
4.27) Hangi replikasyon seenekleri bulunmaktadr?
4.28) Hangi ifreleme seenekleri bulunmaktadr?
d739 1
d852 1
d857 1
a863 1
4.27) Hangi replikasyon seenekleri bulunmaktadr?
d865 1
a865 6
eitli master/slave replikasyon seenekleri bulunmaktadr. Bunlar master veritabannn veritaban deiikliklerini 
yaparken, slave sunucunun sadece veritabannda okuma yapmasna izin verir. 
http://gborg.PostgreSQL.org/genpage?replication_research sayfasnn altnda bunlarn listesini bulabilirsiniz. 
http://gborg.PostgreSQL.org/project/pgreplication/projdisplay.php adresinde, oklu-master replikasyon zm zerinde 
allyor.
4.28) 4.28) Hangi ifreleme seenekleri bulunmaktadr?
d876 1
d881 1
d885 1
d891 1
@


1.4
log
@Update Turkish FAQ.

Devrim GUNDUZ
@
text
@d3 1
a3 1
Son gncelleme : 26 Temmuz 2004 Pazartesi - 16:05:26
d135 3
a137 14
stemci

libpq C ktphanesini, psql ve diger arabirimleri ve binary dosyalar, MS Windows ortamlarnda alsmas iin 
derlemeniz mmkndr. Bu rnekte istemcide MS Windows alyor ve desteklenen Unix platformlarndan birinde alan 
PostgreSQL sunucuna TCP/IP ile balanmaktadr. Datm iindeki win31.mak dosyas ile, Win32 libpg ktphanesi ve psql 
yaratabilirsiniz. PostgreSQL ayn zamanda ODBC istemcileri ile haberleebilmektedir.

Sunucu

Veritaban sunucusu Cygwin kullanarak Windows NT, 2K ya da XP zerinde altrlabilir. Dagtm iindeki 
pgsql/doc/FAQ_MSWIN dosyasn ya da web sitemizdeki MS Windows FAQ'u inceleyebilirsiniz.

Doal Windows NT/2000/XP portu iin u anda almalar devam etmektedir. Windows srm hakknda gncel bilgi iin, 
http://techdocs.postgresql.org/guides/Windows adresini ziyaret edebilirsiniz.
d192 1
a192 1
PostgreSQL'in son srm 7.3.3'tr.
d194 1
a194 1
Her 4 ayda major release karlmas planlanmaktadr.
d289 1
a289 1
da irketinizin bu abamza bata bulunabilecek paras varsa, ltfen http://www.pgsql.com/pg_goodies adresine gidiniz 
@


1.3
log
@Update Turkish FAQ, Devrim GUNDUZ
@
text
@d1 552
a552 378
		PostgreSQL iin Ska Sorulan Sorular (SSS)
                                       
   Son gncelleme : 23 ubat 2004  Pazartesi - 13:34:26

   Bruce Momjian (pgman@@candle.pha.pa.us)
   eviren : Devrim GNDZ (devrim@@gunduz.org), Nicolai Tufar (ntufar@@yahoo.com), Volkan YAZICI (vyazici@@phreaker.net)
   
   Bu belgenin en gncel hali, http://www.gunduz.org/seminer/pg/FAQ_turkish.html ve 
   http://www.PostgreSQL.org/docs/faq-turkish.html 
   adreslerinde gorlebilir.
   
   Platforma zel sorularnz, 
   http://www.PostgreSQL.org/users-lounge/docs/faq.html adresinde yantlanr.
     _________________________________________________________________
   
                             Genel Sorular
                                      
   1.1) PostgreSQL nedir? Nasl okunur?
   1.2) PostgreSQL' in haklar nedir?
   1.3) PostgreSQL, hangi Unix platformlarnda alsr?
   1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
   1.5) PostgreSQL'i nereden indirebilirim?
   1.6) Destei nereden alabilirim?
   1.7) En son srm nedir?
   1.8) Hangi belgelere ulasabilirim?
   1.9) Bilinen hatalar ya da eksik zelliklere nereden ulasabilirim?
   1.10) Nasl SQL grenebilirim?
   1.11) PostgreSQL 2000 ylna uyumlu mudur?
   1.12) Gelitirme takmna nasl katlabilirim?
   1.13) Bir hata raporunu nasl gnderebilirim?
   1.14) PostgreSQL, diger DBMS'lerle nasl karlatrlabilir?
   1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
   
                      Kullanc/istemci Sorular
                                      
   2.1) PostgreSQL icin ODBC srcleri var m?
   2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar bulunmaktadr?
   2.3) PostgreSQL'in grafik kullanc arabirimi var mdr? 
        Report generator var mdr? Gml sorgu dili arabirimi var mdr?
   2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri kullanabilirim?
   
                   Ynetimsel Sorular
                                      

   3.1) PostgreSQL'i, /usr/local/pgsql dizininden baka dizinlere nasl kurabilirim?
   3.2) Postmaster'i baslattgmda, Bad System Call ya da core dumped mesaj 
	alyorum. Neden?
   3.3) Postmaster'i balattmda, IpcMemoryCreate hatas alyorum. Neden?
   3.4) Postmaster'i balattmda, IpcSemaphoreCreate hatas alyorum. Neden?
   3.5) Dier bilgisayarlarn benim PostgreSQL veritaban sunucuma balantlarn nasl 
	kontrol edebilirim?
   3.6) Veritaban motorunu daha iyi baarm icin nasl ayarlayabilirim?
   3.7) Hangi hata ayklama zellikleri bulunmaktadr?
   3.8) Balanmaya alrken, neden "Sorry, too many clients" hatasn alyorum?
   3.9) pgsql_tmp dizininin iindeki dosyalar nelerdir?
   3.10) PostgreSQL srmlerini ykselmek iin neden bir dump/reload ilemi gerekletirmek 
	zorundaym?

                        letimsel Sorular
                                      
   4.1) Binary cursor ve normal cursor arasndaki fark nedir?
   4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
   4.3) psql'in iinde grdm tablolarn ya da dier eylerin listesini nasl alabilirim?
   4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
   4.5) Bir satr, tablo ve veritaban icin en fazla byklk nedir? 
   4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk alan gereklidir?
   4.7) Veritabannda hangi tablo ya da indexlerin tanmlandgn nasl grebilirim?
   4.8) Sorgularm cok yava, ya da indexlerimi kullanmyorlar. Neden?
   4.9) Query-optimizer in sorgularm nasl deerlendirdigini, ileme soktuunu nasl grebilirim?
   4.10) R-tree index nedir?
   4.11) Genetic Query Optimizer nedir?
   4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasl yapabilirim?
	Bu byk(kk harfe duyarl aramalar iin indeksi nasl kullanabilirim?

   4.13) Bir sorguda, bir alann "NULL" olduunu nasl ortaya karabilirim?
   4.14) esitli karakter tipleri arasndaki farklar nelerdir?
   4.15.1) Nasl serial/otomatik artan(auto-incrementing) bir alan yaratabilirim?
   4.15.2) SERIAL giriinin deerini nasl alabilirim?
   4.15.3) currval() ve  nextval() dier kullanclara sorun yaratmaz m?
   4.15.4) Neden sequence saylarn transaction ileminin iptalinden sonra yeniden kullanlyor? Neden sequence/SERIAL 
	kolonumdaki saylarda atlamalar oluyor?
   4.16) OID nedir? TID nedir?
   4.17) PostgreSQL' de kullanlan baz terimlerin anlamlar nelerdir?
   4.18) Neden  "ERROR: Memory exhausted in AllocSetAlloc()"? hatasn alyorum?
   4.19) Hangi PostgreSQL srmn alstrdm nasl grebilirim?
   4.20) Neden large-object ilemlerim, "invalid large obj descriptor"? hatasn veriyor?
   4.21) u andaki zaman ntanml deer olarak kabul eden kolonu nasl yaratrm?
   4.22) Neden IN kullanan subquerylerim ok yava?
   4.23) Outer join ilemini nasl yapabilirim?
   4.24) Ayn anda birden fazla veritabannda nasl ilem yapabilirim?
   4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?
   4.26) Neden PL/pgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?
   4.27) Hangi replikasyon seenekleri bulunmaktadr?
   4.28) Hangi ifreleme seenekleri bulunmaktadr?
	
	PostgreSQL zelliklerini Geniletmek
                                      
   5.1) Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman neden 
	core dump ediyor?
   5.2) PostgreSQL'e nasl yeni veri tipleri/fonksiyonlar ekleyebilirim?
   5.3) Bir tuple dndrmek iin bir C fonksiyonunu nasl yazarm?
   5.4) Bir kaynak dosyasnda deisiklik yaptm. Yeniden derlememe ramen 
	deiiklik geerli olmuyor. Neden?
     _________________________________________________________________
   
                             Genel sorular
                                      
    1.1) PostgreSQL nedir?
    
   PostgreSQL, Post-Gres-Q-L olarak okunur.
   
   PostgreSQL, yeni-nesil VTYS arastrma prototipi olan POSTGRES veritaban 
   ynetim sisteminin gelitirilmesidir. POSTGRES' in zengin veri 
   tiplerini ve gl veri modelini tutarken, SQL'in gelitirilmis alt kmesi 
   olan PostQuel dilini kullanr. PostgreSQL cretsizdir ve kaynak kodu ak datlr.

   PostgreSQL, PostgreSQL gelistirme listesine ye olan bir nternet gelistirici
   takm tarafndan gelitirilir. u andaki koordinatr, Marc G. Fournier 
   (scrappy@@PostgreSQL.org). (Bu takma nasl katlacagnz grenmek iin  
   1.6 numaral maddeyi okuyunuz.) Bu takm, tm PostgreSQL geliiminden sorumludur.

   PostgreSQL 1.01 srmnn yazarlar Andrew Yu ve Jolly Chen idi. Bunlarn dsnda bir ka kisi de uyarlama,
   hata ayklama ve kodun gelistirilmesi iin alsmst. PostgreSQL'in tredigi orijinal Postgres kodu, 
   lisans, lisansst ve akademisyenler tarafindan, Professor Michael Stonebraker ) University of
   California, Berkeley) koordinatrlgnde yazlmstr.
   
   Berkley'deki yazlmm ad Postgres idi. SQL uyumlulugu 1995'te eklenince, ad Postgres 95
   oldu. 1996 ylnn sonlarnda ad PostgreSQL olarak degistirildi.
   
       1.2) PostgreSQL'in haklar nedir?
       
   PostgreSQL Data Base Management System
   
   Portions copyright (c) 1996-2002, PostgreSQL Global Development Group
   Portions Copyright (c) 1994-6 Regents of the University of California
   
   Permission to use, copy, modify, and distribute this software and its
   documentation for any purpose, without fee, and without a written
   agreement is hereby granted, provided that the above copyright notice
   and this paragraph and the following two paragraphs appear in all
   copies.
   
   IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY
   FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES,
   INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND
   ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF CALIFORNIA HAS BEEN
   ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   
   THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
   INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
   MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE
   PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF
   CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
   UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
   
   stteki metin klasik ak-kod lisans olan BSD lisansdr. Kaynak kodun nasl 
   kullanlabileceine dair snrlamalar yoktur. Bu lisansi seviyoruz ve deitirme 
   niyetimiz bulunmamaktadr.
   
       1.3) PostgreSQL, hangi Unix platforlarnda alsr?
    
   Genel olarak, modern bir Unix-uyumlu platform PostgreSQL'i alstracaktr.
   Ayrntl bilgi iin kurulum belgelerine bakabilirsiniz
   
       1.4) Hangi Unix olmayan uyarlamalar bulunmaktadr?
    
   stemci
   
   libpq C ktphanesini, psql ve diger arabirimleri ve binary dosyalar, MS
   Windows ortamlarnda alsmas iin derlemeniz mmkndr. Bu rnekte  istemcide
   MS Windows alsyor ve desteklenen Unix platformlarndan birinde alsan PostgreSQL
   sunucuna TCP/IP ile baglanmaktadr. Datm iindeki win32.mak dosyas ile,
   Win32 libpg ktphanesi ve psql yaratabilirsiniz. PostgreSQL ayn zamanda ODBC
   istemcileri ile haberlesebilmektedir.

   Sunucu

   Veritaban sunucusu Cygwin kullanarak Windows NT, 2K ya da XP zerinde altrlabilir.
   Datm iindeki pgsql/doc/FAQ_MSWN dosyasn ya da web sitemizdeki MS Windows FAQ'u
   inceleyebilirsiniz. 
	
   Doal Windows NT/2000/XP portu iin u anda almalar devam etmektedir. Windows srm  
   hakknda gncel bilgi iin, http://techdocs.postgresql.org/guides/Windows adresini 
   ziyaret edebilirsiniz.
 	
   Ayrca, http://forge.novell.com adresinde Novell Netware 6 portu bulunmaktadr.  

       1.5) PostgreSQL'i nereden indirebilirim?
    
   PostgreSQL iin ana anonim ftp sitesi ftp://ftp.PostgreSQL.org/pub ' dur.
   Yanslar iin, ana web sayfamza bakabilirsiniz.
   
   1.6) Destei nereden alabilirim?
    
   Ana e-posta listesi : pgsql-general@@PostgreSQL.org. PostgreSQL konusundaki tartmalara
   aktr. ye olmak iin, asadaki satrlar e-postanzn gvde ksmna (konu ksmna deil)
   yazp, pgsql-general-request@@PostgreSQL.org adresine gnderin:

    subscribe
    end

   Ayn zamanda, bir digest listesi bulunmaktadr. Bu listeye ye olmak iin, 
    pgsql-general-digest-request@@PostgreSQL.org adresine, body ksmnda
   
    subscribe
    end

   yazan bir e-posta atmanz yeterli olacaktr.

   Digest postalar, ana liste 30k civarnda e-postaya ulastnda yelere gnderilmektedir.

   Buglar iin bir e-posta listesi bulunmaktadr. Bu listeye ye olmak iin,
   pgsql-bugs-request@@PostgreSQL.org adresine, body ksmnda

    subscribe
    end

    yazan bir e-posta atmanz yeterli olacaktr.

   Ayn zamanda, gelitiriciler iin tartma listesi bulunmaktadr. Bu listeye ye olmak
   iin,  pgsql-hackers-request@@PostgreSQL.org adresine,  gvde ksmnda

    subscribe
    end

   yazan bir e-posta atmanz yeterli olacaktr.

   Bunlarn dndaki e-posta listelerine ve PostgreSQL hakknda bilgiye, PostgreSQL WWW 
   ana sayfasndan ulaabilirsiniz:
   
     http://www.PostgreSQL.org

   Ayn zamanda, EFNet ve OpenProjects zerinde, #PostgreSQL adl bir IRC kanal bulunmaktadr. Bunun iin,
    irc -c '#PostgreSQL' "$USER" irc.phoenix.net Unix komutunu kullanabilirsiniz.
   
   Ticari destek veren firmalarn listesine,

   http://www.postgresql.org/users-lounge/commercial-support.html
 
   adresinden ulasabilirsiniz.
   
       1.7) En son srm nedir?
    
   PostgreSQL'in son srm 7.3.3'tr. 

   Her 4 ayda major release karlmas planlanmaktadr.
   
       1.8) Hangi belgelere ulasabilirim?
    
   Datmn icinde, kitapciklar, kitapcik sayfalari ve bazi kk rnekler verilmektedir.
   /doc dizinine baknz. Ayrica, bu el kitapklarn online olarak
   http://www.PostgreSQL.org/docs/ adresinden inceleyebilirsiniz. 

   http://www.PostgreSQL.org/docs/awbook.html ve http://www.commandprompt.com/ppbook 
   adreslerinde PostgreSQL kitaplar bulunmaktadr. PostgreSQL kitablarnn listesine, 
   http://www.ca.PostgreSQL.org/books/ adresinden ulaaiblirsiniz. Ayrca, PostgreSQL 
   konusundaki teknik makalelere de http://techdocs.PostgreSQL.org/ adresinden 
   ulaabilirsiniz.

   psql'in, \d ile baslayan veri tipler, operatorler, fonksiyonlar, aggregateler,vb. ile 
   ilgili gzel komutlar vardr.
   
   Web sitemiz daha fazla belgeyi iermektedir.
   
       1.9) Bilinen hatalar ya da eksik zelliklere nereden ulasabilirim?
    
   PostgreSQL SQL-92 uyumlugugu icindedir, standartlardan fazla da zellikleri
   bulunmaktadr. Bilinen hatalar, eksik zellikler ve gelecek ile ilgili planlar iin
   TODO listesine baknz.
   
       1.10) Nasl SQL grenebilirim?
    
   http:/www.PostgreSQL.org/docs/awbook.html adresindeki kitap SQL gretecektir.
   http://www.commandprompt.com/ppbook adresinde de bir baska PostgreSQL kitab bulunmaktadr.

   http://www.intermedia.net/support/sql/sqltut.shtm,
   http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM
   http://sqlcourse.com ve http://sqlcourse2.com adreslerinde de gzel belgeler bulunmaktadr.

   Bir bakas da,  http://members.tripod.com/er4ebus/sql/index.htm adresinde bulunan
   "Teach Yourself SQL in 21 Days, Second Edition" kitabdr.
   
   Baz kullanclarmz da u kitab nermektedirler: 
	The Practical SQL Handbook, Bowman, Judith S., et al.,Addison-Wesley. Others 
	like The Complete Reference SQL, Groff et al., McGraw-Hill.    

   1.11) PostgreSQL 2000 ylna uyumlu mudur?
    
   Evet. 
   
       1.12) Gelistirme takmna nasl katlabilirim?
    
   ncelikle, en son kaynak kodunu indirin ve web sitemizdeki ya da dagtmn iindeki 
   PostgreSQL Developer belgesini okuyun. Ardindan, pgsql-hackers ve pgsql-patches 
   listelerine ye olun. nc olarak da, pgsql-pacthes listesine yksek kalitede 
   yamalar gnderin.

   PostgreSQL CVS arsivine erisim izni olan, 10 kadar gelistirici bulunmaktadir.
   Hepsi defalarca, diger kisilerin yaptigindan cok daha  yksek-kaliteli patchler 
   gondermislerdir. Ayrica biz de bu gelistiricilerin ekledikleri yamalarin yksek
   kalitede olduguna gveniyoruz.
   
       1.13) Bir hata raporunu nasl gnderebilirim? 

  PostgreSQL BugTool sayfasina gidiniz. O sayfada bir bug bildirmek icin neleri 
  yapmanz gerektigi anlatilmistir.
   
  Ayrca, ftp://ftp.PostgreSQL.org/pub ftp adresimizde, yeni bir PostgreSQL srm 
  ya da yamasi olup olmadigini kontrol ediniz.
   
       1.14) PostgreSQL, diger DBMS'lerle nasl karsilastrlabilir?
    
   Bir yazilimin gcn lmek iin esitli yollar vardir: Yazilimin zellikleri, 
   basarm, gvenilirligi, destegi ve creti.
   
   zellikler

   PostgreSQL mevcut byk ticari veritabanlarinin, transaction, subselect, 
   trigger, view, foreign key referential integrity ve sophisticated locking gibi
   tm zelliklerine sahiptir. Onlarin sahip olmadiklari, kullanici-tanimli tipler 
   (user-defined types), rules, inheritance  ve lock cakmalarn drmek iin 
   multi-version uyumluluk zellikleri bulunmaktadir.
          
   Performans (Baarm)

   PostgreSQL, dier ticari ve ak kaynak kodlu veritabanlaryla yakn baarm salar. 
   Baz alardan daha hzldr, dier alardan da yavatr. MySQL ya da daha zayf 
   veritabanlar ile karlatrldnda,insert/update islemlerinde, transaction bazl 
   alstmz iin daha yavaz. MySQL, yukardaki "zellikler" ksmnda belirtilenlerden
   hi birine sahip deildir. Biz, baarmmz her srmde arttrsak da, esneklik ve 
   gelimi zellikler iin yaplanms durumdayz . PostgreSQL'i MySQL ile karlatran  
   u web sitesine bakabilirsiniz: http://openacs.org/why-not-mysql.html
          
   Gvenilirlik
   DBMSlerin gvenilir olmas gerketigi, yoksa degerleri olmayacagini dsnyoruz
   ok iyi test edilmis, dengeli alsan minimum sayda hata ieren kod sunmaya alsyoruz.
   Her bir srm en az 1 aylk beta testlerinden geirilmektedir. Srm gemiine bakarsanz,
   retime hazr, dengeli ve kararl kodlar sundugumuzu grebilirsiniz. Bu alanda, diger 
   veritaban yaZlmlarna stnlgmz olduguna inanmaktayz

   Destek
   E-posta listemiz, olusan herhangi bir sorunu zebilecek byk sayda kullanc
   ve gelistirici grubunu ierir. Sorununuz iin, en az bir ticari veritaban kadar
   rahat zm bulabilirsiniz. Gelistiricilere, kullanc grubuna, belgelere ve
   kaynak koda direk olarak erisebilme, PostgreSQL destegini, diger DBMSlere gre daha
   nemli klar. Gereksinimi olanlara, ticari destek verilebilir. (Destek iin 1.6 blmne baknz.)
          
   Fiyat
   Ticari ve ticari olmayan tm kullanmlarnz iin PostgreSQL cretsizdir. Kodumuzu, yukarda belirtilen
   BSD-stili lisanstaki snrlamalar hari, rnnzn iine ekleyebilirsiniz.
          
       1.15) PostgreSQL'e maddi adan nasl destek olabilirim?
    
   PostgreSQL, 1996 ylndan beri 1.snf altyapya ashiptir. Bunun iin, yllar boyu alsp bu altyapy
   olusturup yneten Marc Fournier'e tesekkrler.

   Bir ak kaynak kodlu proje iin, kaliteli altyap ok nemlidir. Bu altyap, projenin
   kesilmesini nler ve projenin ilerlemesini hzlandrr.
   
   Tabii ki bu altyap ucuz degildir. slerin yrmesi iin eitli ylk ve anlk 
   harcamalarmz olmaktadr. Eger siz ya da sirketinizin bu abamza bagsta 
   bulunabilecek paras varsa, ltfen http://www.pgsql.com/pg_goodies adresine 
   gidiniz ve bagsta, hibede bulununuz.

   Web sayfasnn PostgreSQL, nc.' den bahsetmesine ragmen, "katkda bulunanlar" 
   (contributors) maddesi sadece PostgreSQL projesini desteklemek iindir ve belirli bir 
   sirketin para kaynag degildir. isterseniz, baglant adresine bir ek gnderebilirsiniz.

   ____________________________________________________________________________
   
                      Kullanc/istemci Sorular
                                      
   2.1) PostgreSQL icin ODBC srcleri var m?
    
   iki tane ODBC srcs bulunmaktadr:  PsqlODBC ve OpenLink ODBC.
   
   PsqlODBC'i http://gborg.postgresql.org/project/psqlodbc/projdisplay.php adresinden 
   indirebilirsiniz.
d554 10
a563 87
  OpenLink ODBC http://www.openlinksw.com adresinden alnabilir.Bu src,
  kendi standart ODBC istemci yazlm ile alstndan, destekledikleri 
  her platformda (Win, Mac, Unix, VMS) PostgreSQL ODBC bulunmalidir.
   
  cretsiz srm olmakla beraber, ticari kalitede destek almak isteyenlere satmak isteyeceklerdir. 
  Sorularnz ltfen postgres95@@openlink.co.uk adresine gnderiniz.
   
        2.2) PostgreSQL'i web sayfalarnda kullanabilmek iin hangi aralar bulunmaktadr?

   http://www.webreview.com adresinde, arka planda veritaban alstran Web sayfalar
   iin giris seviyesinde bilgi bulunmaktadr.
   
   Web ile btnlesme iin, PHP mkemmel bir arabirim sunar. http://www.php.net .
   
   Karmak sorunlar iin, ou kisi Perl arabirimini ve  CGI.pm  ya da mod_perl kullanr.
   

       2.3) PostgreSQL'in grafik kullanc arabirimi var mdr? 
    
   eitli grafik arabirimlerimiz bulunmaktadr. Bunlarn arasnda, PgAccess (http://www.pgaccess.org),
   PgAdmin II (http://www.pgadmin.org, sadece Win32 iin), RHDB Admin (http://sources.redhat.com/rhdb/ )
   ve Rekall (http://www.thekompany.com/products/rekall/) bulunmaktadr. Ayrca, PostgreSQL iin web
   tabanl bir arabirim olan PHPPgAdmin (  http://phppgadmin.sourceforge.net/ ) bulunmaktadr.
   
   Daha ayrntl liste iin http://techdocs.postgresql.org/guides/GUITools adresine bakabilirsiniz.

       2.4) PostgreSQL ile iletiimi kurabilmek iin hangi dilleri kullanabilirim?

     * C (libpq)
     * Embedded C (ecpg)
     * Java (jdbc)
     * Python (PyGreSQL)
     * TCL (libpgtcl)

     Dierleri iin, http://gborg.postgresql.org adresindeki Drivers/Interfaces blmne 
     bakabilirsiniz.
     _________________________________________________________________
   
                       Ynetimsel Sorular
                                      
   3.1) PostgreSQL'i, /usr/local/pgsql dizininden baska dizinlere nasl kurabilirim?
    
   configure betigini alstrrken, --prefix seenegini veriniz.
   
       3.2) postmaster'i baslattgmda, a Bad System Call ya da core dumped mesaj 
	alyorum. Neden?
    
   Bunun birok nedeni olabilir. Ancak ilk kontrol edilmesi gereken sey, ekirdeginize
   System V uzantlarnn kurulu olup olmadgn kontrol etmek olabilir. PostgreSQL 
   shared memory ve semaphores iin ekirdek destegine gereksinim duyar.

       3.3) postmaster'i baslattgmda, a pcMemoryCreate hatas alyorum. Neden?
    
   Ya ekirdeginizde shared memory desteginiz dzgnce yaplandrlmamstr, ya da 
   ekirdeginizdeki mevcut shared memory miktarn bytmeniz gerekecektir. Gereksinim
   duyacagnz miktar, mimarinize ve postmaster iin ayarladgnz tampon ile backend 
   islemi saysna bagldr. Tm sistemler iin, tamponlar ve islemlerde ntanml saylarla,
   ~ 1MB kadar yere gereksinmeniz olacaktir.PostgreSQL Administrator's Guide' a, shared memory 
   ve semaphorelar  hakkndaki ayrntl bilgi iin bakabilirsiniz.

       3.4) postmaster'i baslattgmda, a pcSemaphoreCreate hatas alyorum. Neden?
    
   Eger hata, "pcSemaphoreCreate: semget failed (No space left on device)" ise, 
   ekirdeginiz yeterli semaphore ile yaplandrlmams demektir. Postgres, her 
   bir potansiyel backend iin bir semaphore gereksinmesi duyar. Geici bir zm, 
   postmaster backend islemleri iin daha az miktarda snrla baslatmak olabilir. 
   -N i varsalan deger olan 32'den kk bir degerle baslatnz. Daha kalc bir 
    zm, ekirdeinizin SEMMNS ve SEMMNI parametrelerini ykseltmek olacaktr.
   
   almayan semaphorelar ar veritaban islemlerinde kme yaratabilirler.

   Eger hata mesajnz baska birsey ise, ekirdeginizde semaphore destegini 
   yaplandrmams olabilirsiniz. Shared memory ve semaphorelar hakkndaki daha 
   ayrntl bilgi iin PostgreSQL Administrator's Guide'a bakabilirsiniz.
   
       3.5) Diger bilgisayarlarn benim PostgreSQL veritaban sunucuma baglantlarn 
	nasl kontrol edebilirim?
    
   n tanml olarak, PostgreSQL sadece yerel makineden Unix domain sockets kullanarak 
   baglanlmasna izin verir. Diger makineler, postmaster'a -i etiketini geirmezseniz 
   ve $PGDATA_pg_hba.conf dosyasn dzenleyerek  host-based authentication'a 
   olanak vermezseniz, baglant yapamayacaklardr. 
   
       3.6) Veritabani motorunu daha iyi basarim icin nasl ayarlayabilirim?
  
   Indexler sorgular hzlandrabilir. EXPLAIN komutu, PostgreSQL'in sorgunuzu nasl
   yorumladn ve hangi indexleri kullandigini grmenize izin verir.
d565 3
a567 140
   Eer cok fazla INSERT islemi yapiyorsaniz, bunlar byk bir toplu islem dosyasi kullanp
   COPY komutu ile veritabanina girmeyi deneyiniz. Bu, tekil NSERTlerden daha hzldr.
   ikinci olarak,  BEGN WORK/COMMT transaction blogu iinde olmayan  ifadeler kendi 
   transactionlarindaymis gibi dsnlr. oklu ifadeleri tek bir transaction blou iinde 
   yapabilirsiniz. Bu, transaction overheadini drecektir. Tek bir 
   transaction blou iinde  birden ok ifadeyi altrmay 
   deneyebilirsiniz. Bu, transaction overhead ini drr.
   
   eitli ayarlama seenekleri mevcuttur. fsync() ilemini, postmaster' -o -F seenei ile 
   balatarak devre d brakabilirsiniz. Bu ilem, fsync()'lerin her transactiondan sonra 
   diske flush etmesini engelleyecektir.

   Ayn zamanda, postmaster'i -B seenei ile balatp, backend ilemleri tarafndan kullanlan 
   shared memorf buffers saylarn arttrabilirsiniz. Eger bu parametreyi ok yksek tutarsanz, 
   ekirdeinizin shared memory blgesindeki limiti ama olaslnz yznden postmaster 
   balayamayabilir. Her bir tampon (buffer) 8K'dr. ntanml say ise 64 tampondur.
   
   Ayn ekilde, backend'in -S seeneini geici sralamalar iin backend sreleri tarafndan
   kullanlacak hafzay arttrmak amacyla kullanabilirsiniz. -S seenei kilobayt cinsinden deer alr 
   ve n tanml deeri 512'dir (512 K)
     
   Tablolardaki veriyi bir indekse elemek amacyla gruplama iin CLUSTER komutunu kullanabilirsiniz.
   Ayrntl bilgi iin CLUSTER komutunun yardm sayfasna bakabilirsiniz.

       3.7) Hangi hata ayklama zellikleri bulunmaktadr?

   PostgreSQL, hata ayklama amacyla kullanlabilecek durum bilgisi rapor eden eitli 
   zeliklere sahiptir.
 
   ncelikle, configure betiini --enable-cassert seeneiyle altrrsanz, bir ok assert() backend calmasn 
   gzlemler ve beklenmeyen bir durumda program durdurur.

   Postmaster ve postgres eitli hata ayklama seeneklerine sahiptir. ncelikle, 
   postmaster'i balattnzda, standart kty ve hatalar bir log dosyasna 
   ynlendirdiinize emin olun:

    cd /usr/local/pgsql
    ./bin/postmaster >server.log 2>&1 &

    Bu ilem PostgreSQL ana dizinine server.log dosyas yerletirecektir. Bu dosya sunucunun 
    yaad sorunlar ya da hatalar hakknda yararl bilgiler ierir. -d seenei, hata 
    ayklama seviyesini belirten bir rakam ile kullanlr. Yksek hata ayklama 
    seviyelerinin byk log dosyalar oluturacan unutmaynz.
  
    Eer postmaster almyorsa, postgres backend'ini komut satrndan altrabilir ve SQL ifadenizi
    direk olarak yazabilirsiniz. Bu sadece hata ayklama amacyla nerilir. Burada, noktal virgln deil de
    yeni bir satrn sorguyu sonlandrdn unutmaynz. Eer hata ayklama sembolleri ile derlediyseniz,
    ne olduunu grmek iin bir hata ayklayc kullanabilirsiniz. backend postmasterdan balatlmadndan,
    edeer bir ortamda almamaktadr ve locking/backend etkileim sorunlar artabilir.
   
    Eer postmaster alyorsa, bir pencerede psql'i altrn ve psql tarafndan kullanlan postgres srecinin sre 
    numarasn (PID) bulun. Postgres sreci ile ilikilendirmek iin bir hata ayklarc kullann. Sorgular psql 
    aracl ile altrabilirsiniz. Eer postgres balangcnda hata ayklamak istiyorsanz, PGOPTIONS="-W n" 
    seeneini ayarlayabilir ve psql'i balatabilirsiniz. Bu ilem, balangcn n saniye kadar gecikmesini 
    salayacaktr; bylece hata ayklaycy srece ilikilendirdikten sonra balang srecinin devam etmesini 
    salayabilirsiniz.

    postgres program hata ayklama ve baarm lmleri iin -s, -A ve -t seeneklerine sahiptir.
      
       3.8) Baglanmaya alsken, neden "Sorry, too many clients" hatasn alyorum?
    
   Postmaster'in  ezamanl olarak balatabilecei backend sreleri snrlarn 
   arttrmanz gerekmektedir.
   
   n tanml deer 32 sretir. Bunu, postmaster'i uygun -N deeri ile ya da 
   postgresql.conf dosyasn dzenleyerek yeniden balatmakla arttrabilirsiniz.

   Eer -N deerini 32'den byk yapacaksanz, ayn zamanda -B deerini de deitirmeniz
   gerektiini unutmayn. -B -N'nin en az 2 kat kadar olmaldr; daha iyi baarm iin 
   bu sayy daha da arttrmalsnz. Yksek saydaki backend sreleri iin, eitli ekirdek yaplandrma
   parametrelerini arttrmanz gerekecektir. Yaplmas gerekenler, SHMMAX, SEMMNS, SEMMNI, NPROC, MAXUPRC ve 
   alabilecek dosyalarn maksimum says olan NFILE ve NINODE deerlerini kartrmaktr. Bunun nedeni, PostgreSQL'in 
   izin verilen backend srelerinin says zerinde bir snr olmasdr. Bylelikle sistem kaynaklarnn dna 
   klmayacaktr.

   PostgreSQL'in 6.5 srmne kadar, en fazla backend says 64 idi ve bunu deitirmek iin 
   include/storage/sinvaladt.h dosyas iindeki MaxBAckendid sabitini deitirdek sonra 
   yazlm yeniden derlemek gerekiyordu.
   
   	3.9) pgsql_tmp dizinin iindeki dosyalar nelerdir?
    
   Sorgu alstrc (query executer) tarafndan yaratlan geici dosyalardr. rnegin,
   bir sralama ORDER BY ile yapilacaksa ve sralama backend'in -s parametresinin izin
   verdiginden daha fazla alana gereksinim duyuyorsa, ekstra veriyi tutmak iin geici
   dosyalar yaratlr.

   Geici dosyalar, eger sralama srasnda backend gmezse otomatik olarak silinecektir.
   Eger alsan durumda bir backendiniz yoksa, pg_tempNNN.NN dosyalarn silmeniz gvenlidir..

   3.10) PostgreSQL srmlerini ykselmek iin neden bir dump/reload ilemi gerekletirmek zorundaym?

   PostgreSQL takm ara srmlerde sadece kk deiiklikler yapmaktadr; bu yzden 7.2 
   srmnden 7.2.1'e ykseltmek dump/restore ilemi gerekmemektedir. Ancak, esas srmlerde 
   (rnek: 7.2'den 7.3'e) ounlukla sistem tablolarnn ve veri dosyalarnn i yaps 
   deitirilir. Bu deiiklikler ounlukla karmaktr; dolaysyla veri dosyalarnn 
   geriye dnk uyumluluu ilemlerini yapmyoruz. Dump ilemi, veriyi genel biimde 
   alacandan yeniden ykleme esnasnda veri, yeni i biime uygun ekilde 
   yerletirilecektir.

   Disk biiminin deimedii srmlerde, pg_upgrade betii gncellemenin bir dump/restore 
   gerektirmeden yaplmasn salayacaktr. pg_upgrade betiinin o srm iin bulunup 
   bulunmadn srm notlar iinde bulabilirsiniz.

     _________________________________________________________________
   
			letimsel Sorular

                                      
       4.1) Binary cursor ve normal cursor arasindaki fark nedir?
    
   DECLARE yardm sayfasina bakiniz.
   
       4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
	    
   FETCH yardm sayfasina bakiniz, aya da  SELECT ... LIMIT.... kullannz.
   
   lk birka satr almak isteseniz bile, tm sorgu deerlendirilmek durumunda kalnabilir. ORDER BY ieren bir 
   sorgu dnn. Eer ORDER BY ie eleen bir index varsa, PostgreSQL istenen ilk birka satr ileyebilir, ya da
   tm sorgu istenen satrlar retilene kadar ilenebilir.
   
       4.3) psql'in iinde grdgm tablolarin ya da diger seylerin listesini nasl alabilirim?
    
   pgsql/src/bin/psql/describe.c iindeki psql kaynak kodunu okuyabilirsiniz. Bu kod, 
   psql'in \ ile baslayan komutlarnn ktsn olusturan SQL komutlarini ierir. Ayn 
   zamanda, psql'i -E seenei ile balatp, verdiiniz komutlar altrmak iin yapt 
   sorgularn ktlarn grebilirsiniz.

       4.4) Bir tablodan bir kolonu nasl kaldrabilirim?
    
   Bu zellik (ALTER TABLE DROP COLUMN)  7.3 srm ile gelmitir. Eski srmlerde 
   aadakileri uygulamalsnz: 

    BEGIN;
    LOCK TABLE old_table;
    SELECT ...  -- select all columns but the one you want to remove
    INTO TABLE new_table
    FROM old_table;
    DROP TABLE old_table;
    ALTER TABLE new_table RENAME TO old_table;
    COMMIT;
d569 3
a571 65
       4.5) Bir satr, tablo ve veritaban icin en fazla byklk nedir? 
  
    Snrlar:   
 
    Veritabani icin en fazla byklk nedir?			Snrsz (32 TB'lk veritaban bulunmaktadr)
    Bir tablo icin en fazla byklk nedir?			32 TB
    Bir satr iin en fazla byklk nedir?			1.6 TB
    Bir alan iin en fazla byklk nedir?			1 GB
    Tabloda en fazla satr says katr?			Snrsz
    Bir tabloda olabilecek en fazla kolon says katr? 	Kolon tiplerine bal olarak  250-1600 
    Bir tabloda olabilecek en fazla index says katr?	snrsz

   Tabii ki bunlar aslinda snrsz degildir. Burada belirtilen snrlar, fiziksel 
   snrlarn haricindeki snrlardr. Bo disk alan, hafza/takas alan na bal 
   snrlamalar vardr. Baarm, snr deerlere yaklastka, ya da deerler cok byk 
   olduunda debilir.
   
   Bir tablo iin byklk snr olan 16 TB, iletim sisteminin byk dosya destei olup
   olmamasndan bamszdr. Byk tablolar, 1 GB'lik dosyalarda sakland iin, dosya 
   sistemi snrlarnin bir nemi yoktur.
   
   Tablo ve kolon says byklkleri, n tanml blok bykl 32k ya karlarak 
   arttrlabilir.
   
      4.6) Tipik bir metin dosyasndaki veriyi saklamak iin ne kadar disk alan gereklidir?
    
   Bir PostgreSQL veritaban, veriyi "flat" metin dosyasnda saklamak iin gereken 
   alann 5 kat fazla disk alanna gereksinim duyabilir.

   Her satrnda bir tamsay ve metin (text) ieren, 100.000 satrlk bir dosya dnn. 
   Her satrn ortalama 20 byte olduunu farzedelim. Metin dosyas 2.8 MB olacaktr. Bu veriyi
   tutan PostgreSQL veritaban yaklak 6.4 MB yer kaplayacaktr.

     36 byte: Her bir satr baslg (yaklasik)
   + 24 byte: Bir tamsay (int) alani ve bir metin (text) alan 
   +  4 byte: Sayfada tuple a pointer
   ----------------------------------------
    64 byte -> kayt basna

   PostgreSQL'de data page bykl 8192 byte (8k)dir, dolaysyla:

   8192 byte -> page basna
   -------------------------  =  Her bir veritabani page i bana 128 satr (yaklak)
     Satr basna 64 byte

   100000 veri satr
   --------------------  =  782 veritaban sayfas
       128 satr

    782 veritaban sayfas * sayfa bana 8192 byte =  6,406,144 bytes (6.4 MB)

   Indexler cok fazla yere gereksinim duymazlar, ama indexlenmis veriyi tutacaklarndan
   byk olabilirler.
   
   NULL deerler bitmapler iinde tutulur; dolaysyla ok az yer kaplarlar.

       4.7) Veritabannda hangi tablo ya da indexlerin tanmlandgn nasl grebilirim?
    
    psql, bu tr bilgileri gstermek iin, \ ile balayan bir ok komut sunmaktadr. 
    \? komutu ile bu komutlar grebilirsiniz. Ayrca, bunlar aklayan ve pg_ ile balayan 
    ok sayda sistem tablosu bulunmaktadr. Ayn zamanda, psql -l ile tm veritabanlarn 
    listeyelebirsiniz.
   
   Ayrca, pgsql/src/tutorial/syscat.source kodunu inceleyebilirsiniz. Bu dosya, veritaban 
   sistem dosyalarindan bilgiyi almak iin gereksinim duyulan  bir ok SELECTleri gsterir.
a572 1
    4.8) Sorgularm cok yava, ya da indexlerimi kullanmyorlar. Neden? 
d595 2
a596 2
Eer optimizer'n sral arama yapmasnn yanl olduuna inanyorsanz, SET enable_seqscan TO 'off' kullann ve 
index kullanan aramalarn hala daha hzl olup olmadn grn.
d608 5
a612 5
 4.9) query-optimizer in sorgularm nasl deerlendirdiini, ileme soktuunu nasl grebilirim?
    
   EXPLAIN yardm sayfasna baknz.	
   
       4.10) R-tree index nedir?
d625 10
a634 2
Gml R-tree indexleri poligon ve boxlar kullanabilir. Teorik olarak, R-tree indexlerin zelliklerini 
geniletmek bir miktar aba gerektirir ve bunun nasl yaplacana dair bir belgemiz henz bulunmamaktadr.
d636 6
a641 3
       4.11) Genetic Query Optimizer nedir?
  
   GEQO modl, Genetic Algorith(GA) kullanlarak tablolar birletirildiinde sorgu optimizasyonunu hzlandrr. 
d643 1
a643 8
    4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasl yapabilirim?
	Bu byk(kk harfe duyarl aramalar iin indeksi nasl kullanabilirim?
    
   ~ operatr dzenli ifade elemesi ve ~*  byk/kk harfe duyarsz dzenli ifade elemesi yapar.
   Byk/kk harfe duyarl olan LIKE'in  byk/kk harfe duyarsz olan biini ILIKE'tr ve PostgreSQL
   7.1 srm ile birlikte gelmitir.
     
   Byk-kk harfe duyarsz eitlik karlatrmalar aadaki gibi ifade edilir:
d645 1
a645 3
    SELECT *
    FROM tab
    WHERE lower(col) = 'abc'
d647 1
a647 1
   Bu standart bir indeks yaratmayacaktr. Ancak eer fonksiyonel bir indeks yaratrsanz; o kullanlacaktr:
d649 2
a650 1
    CREATE INDEX tabindex on tab (lower(col));
d652 1
a652 7
    4.13)  Bir sorguda, bir alanin "NULL" oldugunu nasl ortaya karabilirim?
    
   Kolonu, IS NULL ve IS NOT NULL ile test edebilirsiniz.
   
       4.14) esitli karakter tipleri arasndaki farklar nelerdir?
    
Veri Tipi	 Ad              Not
d655 1
a655 1
CHAR(n)         bpchar          belirtilen uzunlupa kadar sonuna  boluk eklenir.
d659 3
d663 34
a696 37
 adlar (internal name) sistem kataloglarn ve baz hata meajlarn incelerken greceksiniz.
  
   lk drt veri tipi "varlena" tipidir (yani, diskteki ilk 4 bayt uzunluktur; devam da veridir.) Dolaysyla,
   Bylece, kullanlan gerek alan, belirtilen alandan biraz daha byktr. Ancak, bu veri tipleri, sktrlmaya tabi 
   tutulabilir; dolaysyla disk alan beklenilenden kck olabilir. VARCHAR(n) bykl artabilen ama en byk 
   uzunluu snrl oan verileri saklamak iin en uygun yntemdir. TEXT, 1 GB bykle kadar olan verileri tutmak iin 
   kullanlr.

   CHAR(n), ayn uzunluktaki dizilerin saklanmas iin kullanmr. CHAR(n) belirtilen uzunlua kadar boluk ile 
   doldurur; ancak VARCHAR(n) sadece verilen karakterleri saklar.BYTEA binary veri saklamak iindir; ayrca "NULL" bayt 
   ieren deerleri de saklar. Burada anlatlan  veri tipi de benzer baarm karakteristiklere sahiptir.
   
       4.15.1) nasl serial/otomatik artan(auto-incrementing) bir alan yaratabilirim?
    
     PostgreSQL'de SERIAL veri tipi vardr. Bu veri tipi bir sequence ve kolon zerinde bir indeks yaratr.

    rnek, aadaki sorgu:

    CREATE TABLE person (
        id   SERIAL,
        name TEXT
    );

    buna evrilir:

    CREATE SEQUENCE person_id_seq;
    CREATE TABLE person (
        id   NT4 NOT NULL DEFAULT nextval('person_id_seq'),
        name TEXT
    );
    CREATE UNIQUE NDEX person_id_key ON person ( id );

  Sequenceler hakknda daha fazla bilgi iin create_sequence yardm sayfasna bakabilirsiniz. Her satrn OID alann 
  tekil bir say olarak alabilirsiniz. Ancak, veritabannzn dump'n alp yeniden yklerseniz, OID deerlerini
  koruyabilmek iin pg_dump'n -o parametresini ya da "COPY WITH OIDS" seeneini kullanmanz gerekecektir.
   
   4.15.2) SERIAL giriinin degerini nasl alabilirim?
d698 1
a698 1
  Bir yaklam, sequence nesnesindeki SERIAL deerini, veriyi girmeden nce nextval() ile alp, aldnz deeri 
d701 2
a702 1
    new_id = execute("SELECT nextval('person_id_seq')");
d705 2
a706 2
  Dier sorgular iin new_id'de yeni deerin saklanmas gerekir. Otomatik olarak yaratlan SEQUENE nesnesinin ad,
  <tablo ad>_<serial kolonu ad>_seq eklinde olacaktr (< > iaretleri olmadan).
d708 1
a708 1
 Alternatif olarak, atanm SERIAL deerini, deer girildikten sonra currval() fonksiyonu ile alabilirsiniz:
d710 35
a744 37
    execute("INSERT INTO person (name) VALUES ('Blaise Pascal')");
    new_id = execute("SELECT currval('person_id_seq')");

  Son olarak, n tanml deeri bulmak iin INSERT ifadesinden dnen OID deerini kullanabilirsiniz; ancak bu
  en az tanabilir zm olacaktr. Perl'de, Edmund Mergl'in DBD:Pg mdl ile birlikte DBI kullanarak, OID deeri
  $sth->execute() altrldktan sonra $sth->(pg_OID_status) ile alnabilir.

       4.15.3) currval() ve  nextval() diger kullanicilara sorun yaratmaz m?
    
   Hayr. curval(), tm kullanclar degil, backend tarafndan atanan geerli  
   degeri dndrr.
   
      4.15.4) Neden sequence saylarn transaction ileminin iptalinden sonra yeniden kullanlyor? Neden sequence/SERIAL 
		kolonumdaki saylarda atlamalar oluyor?

   Uyumluluu arttrmak iin, sequence deerleri alan transactionlara gerektii ekilde aktarlr ve transaction 
   bitene kadar o deer kilitlenmez. Bu, iptal edilen transaction ilemleri nedeniyle boluklara neden olur. 

    4.16) OID nedir? TID nedir?

OIDler, tekil satr numaralarna PostgreSQL'in yantdr. PostgreSQL'de yaratlan her say, tekil bir OID alr. 
initdb ilemi srasnda yaratlan tm OID'ler 16384'ten kktr (backend/access/transam.h). Kullanclar tarafndan 
yaratlan tm OID'ler bu sayya eit ya da bu saydan byktr. Varsaylan durumda, tm bu OIDler sadece bir tablo ya 
da veritabannda deil, tm PostgreSQL kurulumunda tekildir.

PostgreSQL OIDleri, tablolar arasnda satrlar ilikilendirmek iin kendi i tablolarnda kullanr. Bu OIDler 
belirli kullanc satrlarn belirtmek iin kullanabilir ve join ilemlerinde kullanlr. OID deerlerini saklamak 
iin OID kolon tipini kullanmanz nerinir. Daha hzl bir eriim iin, OID alannda bir index yaratabilirsiniz.

OID'ler yeni satrlara, tm veritabanlar tarafnda kullanlan ortak bir alandan atanrlar. Eer OID'i baka bir 
deere eitlemek isterseniz ya da tablonun bir kopyasn orijinal OIDler ile karmak isterseniz, bu mmkndr:

        CREATE TABLE new_table(old_OID OID, mycol int);
        SELECT old_OID, mycol NTO new FROM old;
        COPY new TO '/tmp/pgtable';
        DELETE FROM new;
        COPY new WITH OIDS FROM '/tmp/pgtable';
d751 24
a774 53
   
       4.17) PostgreSQL'de kullanlan baz terimlerin anlamlar nelerdir?
    
   Kaynak kodun bir ksm ve eski belgeler, daha geni kullanm alan olan terimleri
   kullanrlar. Bunlarn bazlar:

     * table, relation, class
     * row, record, tuple
     * column, field, attribute
     * retrieve, select
     * replace, update
     * append, insert
     * OID, serial value
     * portal, cursor
     * range variable, table name, table alias

  Genel veritaban terimleri,

    http://hea-www.harvard.edu/MST/simul/software/docs/pkgs/pgsql/glossary/glossary.html
   adresinde bulunabilir.
   
       4.18) Neden  "ERROR: Memory exhausted in AllocSetAlloc()"? hatasn alyorum?
    
   Sisteminizde sanal belleinizi tketmis olabilirsiniz, ya da ekirdeiniz
   belli kaynaklar icin dk bir snra sahip olabilir. Postmaster'i balatmadan nce 
   aadakileri deneyebilirsiniz:

    ulimit -d 262144
    limit datasize 256m

   Kabuunuza bal olarak, bunlardan sadece biri olumlu sonu verecektir, ama
   bu ilem veri segment snrnz arttracak, ve belki de sorgunuzun tamamlanmasn
   saglayacaktr. Bu komut, varolan srece (current process) ve komut alstrldktan
   sonraki tm alt islemlere uygulanr. Eer SQL istemcinizle, backendin ok fazla veri 
   dndrmesi nedeniyle bir sorun yayorsanz, bunu istemciyi balatmadan nce deneyiniz.
   
       4.19) Hangi PostgreSQL srmn alstrdgm nasl grebilirim?
    
   psql arabiriminde, SELECT version(); yaznz.
   
   4.20) Neden large-object islemlerim, "invalid large obj descriptor"? hatasn veriyor?

   Large object ilemlerinizin ularna, yani  lo_open ... lo_close komutlarnn evresine, 
    BEGIN WORK ve COMMIT koymanz gerekmektedir.

   Eger ODBC gibi bir istemci arabirimi kullanyorsanz, auto-commit'i kapatmanz gerekebilir.
   
   4.21) u andaki zaman ntanml deer olarak kabul eden kolonu nasl yaratabilirim?
    
   Alttakini kullanabilirsiniz:

   CURRENT_TIMESTAMP:
	CREATE TABLE test (x int, modtime timestamp DEFAULT CURRENT_TIMESTAMP );
d776 5
a780 1
   4.22) Neden IN kullanan subquerylerim ok yavas?
d782 2
a783 2
7.4 srmnden nce, subqueryler. Eer subquery sadece birka satr ve outer query bol sayda satr dndryorsa, IN 
en hzlsdr. Sorgular hzlandrmak iin IN yerine EXISTS kullann:
d785 23
a807 1
    SELECT *
d809 2
a810 1
    WHERE col IN (SELECT subcol FROM subtab);
d814 1
a814 1
    SELECT *
d816 2
a817 1
    WHERE EXISTS (SELECT subcol FROM subtab WHERE subcol = col);
d819 1
a819 67
 Bunun hzl olabilmesi iin, subcol'un indekslenmi bir kolon olmas gerekmektedir.
 
	7.4 srm ve sonrasnda, IN aslnda normal sorgularla ayn karmak join tekniklerini kullanr ve EXISTS'e tercih 
	edilir.
   
       4.23) Outer join islemini nasl yapabilirim?
    
   PostgreSQL outer join ilemlerini SQL standartlarn kullanarak gerekletirmektedir.
   Aada 2 rnek bulunmaktadr:

    SELECT *
    FROM t1 LEFT OUTER JON t2 ON (t1.col = t2.col);

   ya da 

    SELECT *
    FROM t1 LEFT OUTER JON t2 USNG (col);

   Bu zde sorgular t1.col ' i  t2.col'ye join ederler ve ayn zamanda t1'deki unjoined satrlar 
   (t2'de elenmenis olanlarla) dndrrler. RIGHT JON t2'nin unjoined satrlarn ekleyecektir.
   Bir FULL join, elemi btn satrlar ve t1 ile t2'den tm balanmam (unjoined) satrlar alr.
   OUTER szc seimseldir ve LEFT, RIGHT ve FULL join ilemlerinde olduu kabul edilir. Sradan 
   join ilemleri INNER join olarak adlandrlr.

   nceki srmlerde, OUTER JOINler UNION ve NOT IN kullanlarak simle edilebiliyordu. rnein, tab1 
   ve tab2'yi birletirirken, aadaki sorgu iki tablonun dtan balanmasn salar:

    SELECT tab1.col1, tab2.col2
    FROM tab1, tab2
    WHERE tab1.col1 = tab2.col1
    UNION ALL
    SELECT tab1.col1, NULL
    FROM tab1
    WHERE tab1.col1 NOT N (SELECT tab2.col1 FROM tab2)
    ORDER BY col1

       4.24) Ayn anda birden fazla veritabannda nasl ilem yapabilirim?

   Mevcut veritabannz dsndaki baska bir veritabannz sorgulamanzn bir yolu bulunmamaktadr.
   bunun nedeni, PostgreSQL'in veritabanna zel sistem kataloglar yklemesidir. Bu nedenle, 
   cross-database bir sorgunun nasl davranacagn kestirmek zordur.
   
   contrib/dblink fonksiyon arlarn kullanarak cross-database sorgulara izin vermektedir. Tabii ki, 
   bir istemci deiik veritabanlarna ayn anda eriim salayabilir ve bilgiyi bu sekilde
   birletirebilir.

   4.25) Bir fonksiyondan nasl oklu satr ya da kolon dndrebilirim?

   7.3 srmnde, bir fonksiyondan kolaylkla oklu satr ya da stun dndrebilirsiniz.

	http://techdocs.postgresql.org/guides/SetReturningFunctions .

   4.26) Neden PL/pgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?

   PL/pgSQL fonksiyon ierikleri cacheler. Bunun istenmeyen bir taraf, eer bir PL/pgSQL fonksiyonu geici bir
   tabloya eriiyorsa ve bu tablo ileride kaldrlp yeniden oluturulduktan sonra fonksiyon yeniden arlrsa,
   fonksiyon almayacaktr; nk cachelenmi fonksiyon hala eski geici tabloyu gsteriyor olacaktr. zm,
   geici tablo eriimleri iin PL/pgSQL'de EXECUTE kullanmaktr. Bu, sorgunun her seferinde yeniden ilenmesini
   salayacaktr.

   4.27) Hangi replikasyon seenekleri bulunmaktadr?

   eitli master/slave replikasyon seenekleri bulunmaktadr. Bunlar master veritabannn veritaban deiikliklerini 
   yaparken, slave sunucunun sadece veritabannda okuma yapmasna izin verir. 
   http://gborg.PostgreSQL.org/genpage?replication_research sayfasnn altnda bunlarn listesini bulabilirsiniz.
   http://gborg.PostgreSQL.org/project/pgreplication/projdisplay.php adresinde, oklu-master replikasyon zm 
   zerinde allyor.
d821 60
a880 1
   4.28) Hangi ifreleme seenekleri bulunmaktadr?
d883 5
a887 6
    * stemciden sunucuya iletiimi ifrelemek iin, sunucuda ssl seenei postgresql.conf iinde ak olmaldr.
      Ayrca,pg_hba.conf dosyas iinde host ya da hostssl kayd mutlaka olmaldr ve istemci sslmode 
      kapatlmamaldr. (Ayn zamanda,PostgreSQL'in doal SSL balantlar dnda ssh ya da ssl gibi 3.parti 
      ifrelenmi veri iletimi de mmkndr.)
    * Veritaban kullanc ad ve ifreleri 7.3 srm ile birlikte otomatik olarak ifrelenirler. nceki 
      srmlerde, postgresql.conf iindeki PASSWORD_ENCRYPTION seeneini aktif hale getirmeniz gerekmektedir.
d890 18
a907 27
     _________________________________________________________________
   
    		PostgreSQL zelliklerini Geniletmek

    5.1)  Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman neden core dump ediyor?
    
   Sorunun nedeni birden fazla sey olabilir. Kullanici-tanimli fonksiyonunuzu stand-alone bir programda
   calistirmayi deneyiniz.
   
    5.2) PostgreSQL'e nasl yeni veri tipleri/fonksiyonlar ekleyebilirim?
    
   almalarnz pgsql-hackers e-posta listesine gnderiniz. Kodunuz incelendikten sonra
   /contrib dizinine konacaktr.
   
    5.3) Bir tuple dndrmek icin bir C fonksiyonunu nasl yazarm?
    
     PostgreSQL 7.3 srm ile birlikte, C, PL/pgSQL ve SQL kullanlarak tablo-dndren 
     fonksiyonlar tamamen desteklenmektedir. Ayrntl bilgi iin "Programmer's Guide" a 
     bakabilirsiniz. Bir rnei contrib/tablefunc iinde bulabilirsiniz.

    5.4) Bir kaynak dosyasnda deiiklik yaptm. Yeniden derlememe ramen deiiklik 
     geerli olmuyor. Neden?
    
   Makefile'lar include dosyalar iin tam bir bamllk iermezler. 
   ncelikle make clean, ardndan da baska bir make ilemi yapmanz gerekir.
   GCC kullanyorsaniz, configure betiinin --enable-depend seeneini, derleyicinin
   bamllklar otomatik olarak hesaplamas iin kullanabilirsiniz. 
@


1.2
log
@Update Turkish FAQ, Devrim GUNDUZ
@
text
@d3 1
a3 1
   Son gncelleme : 19.05.2003 Cuma 05:03
d6 1
a6 1
   eviren : Devrim GNDZ (devrim@@gunduz.org), Nicolai Tufar (ntufar@@yahoo.com), Volkan Yazc (volkany@@celiknet.com)
d8 1
a8 1
   Bu belgenin en gncel hali, http://www.gunduz.org/seminer/pg/FAQ_turkish ve 
d63 1
a63 1
   4.3) psql'in iinde grdm tablolarn ya da dier eylerin listesini nasil alabilirim?
d72 2
a73 2
   4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasil yapabilirim?
	Bu byk(kk harfe duyarl aramalar iin indeksi nasil kullanabilirim?
d92 1
a92 1
   4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?
d172 1
a172 1
   sunucuna TCP/IP ile baglanmaktadr. Datm iindeki win31.mak dosyas ile,
d178 2
a179 2
   Veritaban sunuucsu Cygwin kullanarak Windows NT, 2K ya da XP zerinde calistirilabilir.
   Dagtm iindeki pgsql/doc/FAQ_MSWN dosyasn ya da web sitemizdeki MS Windows FAQ'u
d188 1
a188 1
       1.5) PostgreSQL'in nereden indirebilirim?
d195 2
a196 2
   Ana e-posta listesi : pgsql-general@@PostgreSQL.org. PostgreSQL konusundaki tartsmalara
   aktr. ye olmak iin, asagdaki satrlar e-postanizin body ksmna (konu ksmna degil)
d210 1
a210 1
   Digest postalar, ana liste 30k civarnda e-postaya ulastiginda yelere gnderilmektedir.
d213 1
a213 1
   email to pgsql-bugs-request@@PostgreSQL.org adresine, body ksmnda
d220 2
a221 2
   Ayn zamanda, gelistiriciler iin tartsma listesi bulunmaktadr. Bu listeye ye olmak
   iin,  pgsql-hackers-request@@PostgreSQL.org adresine,  body ksmnda
d228 2
a229 2
   Bunun dsndaki e-posta listelerine ve PostgreSQL hakknda bilgiye, PostgreSQL WWW 
   ana sayfasndan ulasabilirsiniz:
d233 1
a233 1
   Ayn zamanda, EFNet zerinde, #PostgreSQL adl bir RC kanal bulunmaktadr. Bunun iin,
d321 1
a321 1
   (user-defined types), rules, inheritance  ve lock caksmalarini dsrmek icin 
d463 1
a463 1
       3.6) Veritabani motorunu daha iyi basarim icin nasil ayarlayabilirim?
d580 1
a580 1
       4.2) Sorgunun sadece ilk birka satrn nasil SELECT edebilirim?
d584 3
a586 5
   The entire query may have to be evaluated, even if you only want the
   first few rows. Consider a query that has an ORDER BY. f there is an
   index that matches the ORDER BY, PostgreSQL may be able to evaluate
   only the first few records requested, or the entire query may have to
   be evaluated until the desired rows have been generated.
d588 1
a588 1
       4.3) psql'in iinde grdgm tablolarin ya da diger seylerin listesini nasil alabilirim?
d613 2
a614 2
    Veritabani icin en fazla byklk nedir?			Snrsz (4 TB'lk veritaban bulunmaktadr)
    Bir tablo icin en fazla byklk nedir?			16 TB
d665 1
a665 1
       4.7) Veritabannda hangi tablo ya da indexlerin tanmlandgn nasil grebilirim?
d676 16
a691 15

 Indexes are not automatically used by every query. Indexes are only used if the table is larger than a minimum size,
and the query selects only a small percentage of the rows in the table. This is because the random disk access caused
by an index scan can be slower than a straight read through the table, or sequential scan.

To determine if an index should be used, PostgreSQL must have statistics about the table. These statistics are
collected using VACUUM ANALYZE, or simply ANALYZE. Using statistics, the optimizer knows how many rows are in the
table, and can better determine if indexes should be used. Statistics are also valuable in determining optimal join
order and join methods. Statistics collection should be performed periodically as the contents of the table change.

Indexes are normally not used for ORDER BY or to perform joins. A sequential scan followed by an explicit sort is
usually faster than an index scan of a large table.
However, LIMIT combined with ORDER BY often will use an index because only a small portion of the table is returned.
In fact, though MAX() and MIN() don't use indexes, it is possible to retrieve such values using an index with ORDER
BY and LIMIT:
d698 2
a699 2
   Eer optimizer'in sequential scan ileminde hata yaptn dnyorsanz, SET enable_seqscan TO 'off' 'u kullannz 
   ve index scan'in hala hzl olup olmadn grmek iin testler yapnz.
d701 1
a701 1
   LIKE ya da ~ gibi operatorler kullaniyorsanz, indeksler sadece aadaki koullarda kullanlabilir:
d703 3
a705 3
    * Arama dizininin ba, dizinin ba ile balanmaldr. Yani, 
	  o LIKE sorgular % ile balamamaldr.
	  o Dzenli ifade sorgular ^ ie balamamaldr.
d707 3
a709 3
    * ILIKE ve ~* gibi  byk/kk harfe duyarsz  aramalar indekslerden yararlanmazlar. Onun yerine, blm 4.12'de 
anlatlan fonksiyonel indeksleri kullanabilirsiniz.
    * initdb srasnda ntanml C localei kullanlmaldr.
d716 4
d721 1
a721 4
   An R-tree index is used for indexing spatial data. A hash index can't handle range searches. A B-tree index only
handles range searches in a single dimension. R-trees can handle multi-dimensional data. For example, if an R-tree
index can be built on an attribute of type point, the system can more efficiently answer queries such as "select all
points within a bounding rectangle."
d723 2
a724 1
The canonical paper that describes the original R-tree design is:
d726 1
a726 2
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.
d728 2
a729 1
Bu paperi, Stonebraker'n "Readings in Database Systems" kitabnda bulabilirsiniz.
a730 4
Built-in R-trees can handle polygons and boxes. In theory, R-trees can be extended to handle higher number of
dimensions. In practice, extending R-trees requires a bit of work and we don't currently have any documentation on
how to do it.
    
d734 3
a736 4
   It  allows the handling of large   join queries through nonexhaustive search.
   
    4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasil yapabilirim?
	Bu byk(kk harfe duyarl aramalar iin indeksi nasil kullanabilirim?
d752 1
a752 1
    4.13)  Bir sorguda, bir alanin "NULL" oldugunu nasil ortaya karabilirim?
d778 1
a778 1
       4.15.1) Nasil serial/otomatik artan(auto-incrementing) bir alan yaratabilirim?
d785 1
a785 1
        id   SERAL,
d802 4
a805 5
   4.15.2) SERIAL giriinin degerini nasil alabilirim?
    
One approach is to retrieve the next SERIAL value from the sequence object with the nextval() function before
inserting and then insert it explicitly. Using the example table in 4.15.1, an example in a pseudo-language would
look like this:
d810 2
a811 4
You would then also have the new value stored in new_id for use in other queries (e.g., as a foreign key to the
person table). Note that the name of the automatically created SEQUENCE object will be named
<table>_<serialcolumn>_seq, where table and serialcolumn are the names of your table and your SERIAL column,
respectively.
d819 2
a820 2
  en az tanabilir zm olacaktr. Perl'de, Edmund Mergl'in DBD:Pg mdl ile birlikte DBI kullanarak, oid deeri
  $sth->execute() altrldktan sonra $sth->(pg_oid_status) ile alnabilir.
d834 15
a848 20
    
   ODs are PostgreSQL's answer to unique row ids. Every row that is
   created in PostgreSQL gets a unique OD. All ODs generated during
   initdb are less than 16384 (from backend/access/transam.h). All
   user-created ODs are equal to or greater than this. By default, all
   these ODs are unique not only within a table or database, but unique
   within the entire PostgreSQL installation.
   
   PostgreSQL uses ODs in its internal system tables to link rows
   between tables. These ODs can be used to identify specific user rows
   and used in joins. t is recommended you use column type OD to store
   OD values. You can create an index on the OD field for faster
   access.
   
   ODs are assigned to all new rows from a central area that is used by
   all databases. f you want to change the OD to something else, or if
   you want to make a copy of the table, with the original ODs, there is
   no reason you can't do it:
        CREATE TABLE new_table(old_oid oid, mycol int);
        SELECT old_oid, mycol NTO new FROM old;
d851 4
a854 1
        COPY new WTH ODS FROM '/tmp/pgtable';
d856 2
a857 7
   ODs are stored as 4-byte integers, and will overflow at 4 billion. No
   one has reported this ever happening, and we plan to have the limit
   removed before anyone does.
   
   TIDs are used to identify specific physical rows with block and offset
   values. TDs change after rows are modified or reloaded. They are used
   by index entries to point to physical rows.
d861 1
a861 1
   Kaynak kodun bir ksm ve eski belgeler, daha genis kullanm alan olan terimleri
d881 3
a883 3
   Sisteminizde sanal belleginizi tketmis olabilirsiniz, ya da ekirdeginiz
   belli kaynaklar icin dk bir snra sahip olabilir. postmasteri baslatmadan nce 
   asagidakileri deneyebilirsiniz:
d890 3
a892 3
   saglayacaktr. Bu komut, varolan isleme (current process) ve komut alstrldktan
   sonraki tm alt islemlere uygulanir. Eger SQL istemcinizle, backendin ok fazla veri 
   dndrmesi nedeniyle bir sorun yasyorsanz, bunu istemciyi baslatmadan nce deneyiniz.
d894 1
a894 1
       4.19) Hangi PostgreSQL srmn alstrdgm nasil grebilirim?
d896 1
a896 1
   psql arabiriminde, select version(); yaznz.
d900 2
a901 2
   Large object islemlerinizin uclarina, yani  lo_open ... lo_close komutlarnn evresine, 
    BEGIN WORK ve COMMIT koymanz gerekmektedir;
d905 1
a905 1
   4.21) Su andaki zaman ntanml deger olarak kabul eden How do  create a column that will default to the current time?
a912 3
    
   Currently, we join subqueries to outer queries by sequentially scanning the result of the subquery for 
   each row of the outer query. IN' i EXISTS ile deitirerek bir zme ulalabilir.
d914 4
a917 1
SELECT *
d919 1
a919 1
    WHERE col1 N (SELECT col2 FROM TAB2)
d921 3
a923 2
   to:
SELECT *
d925 1
a925 1
    WHERE EXSTS (SELECT col2 FROM TAB2 WHERE col1 = col2)
d927 4
a930 1
   Bu snrlamay ilerdeki srmlerimizde dzeltmeyi planlamaktayz.
d932 1
a932 1
       4.23) Outer join islemini nasil yapabilirim?
d934 2
a935 2
   PostgreSQL outer joins islemlerini SQL standartlarn kullanarak gereklestirmektedir.
   Asagida 2 rnek bulunmaktadr:
d945 3
a947 3
   Bu zdes sorgular t1.col ' i  t2.col'ye join ederler ve ayn zamanda t1'deki unjoined satrlar 
   (t2'de eslenmenis olanlarla) dndrrler. RGHT JON t2'nin unjoined satrlarn ekleyecektir.
   Bir FULL join, elemi btn satrlar ve t1 ile t2'den tm balanmam (unjoined) satrlar alr.
d963 2
a964 2
       4.24) Ayni andan birden fazla veritabaninda nasil islem yapabilirim?
    
d967 1
a967 1
   cross-database bir sorgunun nasil davranacagn kestirmek zordur.
d969 3
a971 3
   contrib/dblink fonksiyon arlarn kullanarak cross-database sorgulara izin verid. Tabii ki, 
   bir istemci degisik veritabanlarna ayn anda erisim saglayabilir ve bilgiyi bu sekilde
   birlestirebilir.
d977 1
a977 1
	http://techdocs.postgresql.org/guides/SetReturningFunctions.
d979 1
a979 1
   4.26) Neden Pl/PgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?
d981 1
a981 1
   PL/PgSQL fonksiyon ierikleri cacheler. Bunun istenmeyen bir taraf, eer bir PL/PgSQL fonksiyonu geici bir
d984 1
a984 1
   geici tablo eriimleri iin PL/PgSQL'de EXECUTE kullanmaktr. Bu, sorgunun her seferinde yeniden ilenmesini
d998 4
a1001 1
    * stemciden sunucuya iletiimi ifrelemenin tek yolu, pg_hba.conf iinde hostssl kullanmaktr.
d1003 1
a1003 1
     srmlerde, postgresql.conf iindeki PASSWORD_ENCRYPTION seeneini aktif hale getirmeniz gerekmektedir.
d1010 1
a1010 1
    5.1)  Kullanici-tanimli bir fonksiyon yazdim. psql'de alistirdigim zaman neden core dump ediyor?
d1015 1
a1015 1
    5.2) PostgreSQL'e nasil yeni tipler/fonksiyonlar ekleyeiblirim?
d1017 1
a1017 1
   alsmalarnz pgsql-hackers e-posta listesine gnderiniz. Kodunuz incelendikten sonra
d1020 1
a1020 1
    5.3) Bir tuple dondrmek icin bir C fonksiyonunu nasil yazarm?
d1022 1
a1022 1
     PostgreSQL 7.3 srm ile birlikte, C, PL/PgSQL ve SQL kullanlarak tablo-dndren 
d1024 1
a1024 1
    bakabilrisiniz. Bir rnei contrib/tablefunc iinde bulabilirsiniz.
d1027 1
a1027 1
geerli olmuyor. Neden?
@


1.2.4.1
log
@Update Turkish FAQ, Devrim GUNDUZ
@
text
@d3 1
a3 1
   Son gncelleme : 23 ubat 2004  Pazartesi - 13:34:26
d6 1
a6 1
   eviren : Devrim GNDZ (devrim@@gunduz.org), Nicolai Tufar (ntufar@@yahoo.com), Volkan YAZICI (vyazici@@phreaker.net)
d8 1
a8 1
   Bu belgenin en gncel hali, http://www.gunduz.org/seminer/pg/FAQ_turkish.html ve 
d63 1
a63 1
   4.3) psql'in iinde grdm tablolarn ya da dier eylerin listesini nasl alabilirim?
d72 2
a73 2
   4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasl yapabilirim?
	Bu byk(kk harfe duyarl aramalar iin indeksi nasl kullanabilirim?
d92 1
a92 1
   4.26) Neden PL/pgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?
d172 1
a172 1
   sunucuna TCP/IP ile baglanmaktadr. Datm iindeki win32.mak dosyas ile,
d178 2
a179 2
   Veritaban sunucusu Cygwin kullanarak Windows NT, 2K ya da XP zerinde altrlabilir.
   Datm iindeki pgsql/doc/FAQ_MSWN dosyasn ya da web sitemizdeki MS Windows FAQ'u
d188 1
a188 1
       1.5) PostgreSQL'i nereden indirebilirim?
d195 2
a196 2
   Ana e-posta listesi : pgsql-general@@PostgreSQL.org. PostgreSQL konusundaki tartmalara
   aktr. ye olmak iin, asadaki satrlar e-postanzn gvde ksmna (konu ksmna deil)
d210 1
a210 1
   Digest postalar, ana liste 30k civarnda e-postaya ulastnda yelere gnderilmektedir.
d213 1
a213 1
   pgsql-bugs-request@@PostgreSQL.org adresine, body ksmnda
d220 2
a221 2
   Ayn zamanda, gelitiriciler iin tartma listesi bulunmaktadr. Bu listeye ye olmak
   iin,  pgsql-hackers-request@@PostgreSQL.org adresine,  gvde ksmnda
d228 2
a229 2
   Bunlarn dndaki e-posta listelerine ve PostgreSQL hakknda bilgiye, PostgreSQL WWW 
   ana sayfasndan ulaabilirsiniz:
d233 1
a233 1
   Ayn zamanda, EFNet ve OpenProjects zerinde, #PostgreSQL adl bir IRC kanal bulunmaktadr. Bunun iin,
d321 1
a321 1
   (user-defined types), rules, inheritance  ve lock cakmalarn drmek iin 
d463 1
a463 1
       3.6) Veritabani motorunu daha iyi basarim icin nasl ayarlayabilirim?
d580 1
a580 1
       4.2) Sorgunun sadece ilk birka satrn nasl SELECT edebilirim?
d584 5
a588 3
   lk birka satr almak isteseniz bile, tm sorgu deerlendirilmek durumunda kalnabilir. ORDER BY ieren bir 
   sorgu dnn. Eer ORDER BY ie eleen bir index varsa, PostgreSQL istenen ilk birka satr ileyebilir, ya da
   tm sorgu istenen satrlar retilene kadar ilenebilir.
d590 1
a590 1
       4.3) psql'in iinde grdgm tablolarin ya da diger seylerin listesini nasl alabilirim?
d615 2
a616 2
    Veritabani icin en fazla byklk nedir?			Snrsz (32 TB'lk veritaban bulunmaktadr)
    Bir tablo icin en fazla byklk nedir?			32 TB
d667 1
a667 1
       4.7) Veritabannda hangi tablo ya da indexlerin tanmlandgn nasl grebilirim?
d678 15
a692 16
Indexler her sorgu tarafndan otomatik olarak kullanlmazlar. Indexler eer bir tablonun bykl minimum bir 
byklkten fazla ise ve sorgu tablodaki satrlarn sadece kk bir yzdesini seiyorsa kullanlr. Bunun nedeni, 
index eriiminin neden olduu raslansal disk eriimi nin diskin ya da tablonun sral okunmasndan daha yavas 
olabilmesidir.

Bir index'in kullanlp kullanlmayacan belirlemek iin, PostgreSQL tablo hakkndaki istatistiklere gereksinmesi 
vardr. Bu istatistikler, VACUUM ANALYZE kullanlarak toplanrlar. Optimizer, istatistikleri kullanarak, tabloda ka 
satr olduunu ve bilir ve indexin kullanlp kullanlmayacana daha iyi karar verir. Istatistikler, ayn zamanda en 
uygun join srasn ve yntemini belirlemekte ok nemlidir. statistik toplanmas, tablo ierikleri deitike 
periyodik olarak yaplmaldr.

Indexler normalde ORDER BY sorgular ya da join ilemlerini gerekletirmek iin kullanlmazlar. Ak bir sralamay 
takip eden sral bir arama (sequential scan), byk bir tabloda index aramas yapmaktan genelde daha hzldr.
Ancak, ORDER BY ile birlemi LIMIT genellikle bir index kullanacaktr; nk tablonun sadece belirli bir miktar 
dndrlecektir. Aslnda, MAX() ve MIN() fonksiyonlarnn index kullanmamalarndan dolay, bu gibi deerleri ORDER BY 
ve LIMIT kullanarak da almak olasdr:
d699 2
a700 2
Eer optimizer'n sral arama yapmasnn yanl olduuna inanyorsanz, SET enable_seqscan TO 'off' kullann ve 
index kullanan aramalarn hala daha hzl olup olmadn grn.
d702 1
a702 1
LIKE ya da ~ gibi operatrler kullanyorsanz, index'ler sadece aadaki koullarda kullanlabilir:
d704 3
a706 3
    * Arama dizininin ba, dizinin ba ile balanmaldr. Yani,
          o LIKE sorgular % ile balamamaldr.
          o Dzenli ifade sorgular ^ ie balamamaldr.
d708 3
a710 3
    * ILIKE ve ~* gibi byk/kk harfe duyarsz aramalar index'lerden yararlanmazlar. Onun yerine, blm 4.12'de 
anlatlan fonksiyonel index'leri kullanabilirsiniz.
    * initdb srasnda ntanml C locale'i kullanlmaldr.
a716 4
R-tree index, uzaysal (spatial) verileri indexlemek iin kullanlr. Bir hash index, dizi aramalarnda (range search) 
kullanlamaz. B-tree index dizi aramalarnda sadece tek boyutlu almaktadr. R-tree, ok boyutlu veriyi destekler. 
rnein, eer bir R-tree index point veri tipi zerinde ina edililebilirse, sistem "select all points within a 
bounding rectangle" gibi sorgulara daha verimli yantlar verecektir.
d718 6
a723 1
Orijinal R-tree tasarmn aklayan belge:
d725 1
a725 1
Guttman, A. "R-trees: A Dynamic Index Structure for Spatial Searching." Proceedings of the 1984 ACM SIGMOD Int'l Conf 
d728 1
a728 4
Bu belgeyi, Stonebraker'n "Readings in Database Systems" kitabnda bulabilirsiniz.

Gml R-tree indexleri poligon ve boxlar kullanabilir. Teorik olarak, R-tree indexlerin zelliklerini 
geniletmek bir miktar aba gerektirir ve bunun nasl yaplacana dair bir belgemiz henz bulunmamaktadr.
d730 4
d737 4
a740 3

    4.12) Dzenli ifade (Regular Expression) aramalarn ve byk/kk harfe duyarsz aramalar nasl yapabilirim?
	Bu byk(kk harfe duyarl aramalar iin indeksi nasl kullanabilirim?
d756 1
a756 1
    4.13)  Bir sorguda, bir alanin "NULL" oldugunu nasl ortaya karabilirim?
d782 1
a782 1
       4.15.1) nasl serial/otomatik artan(auto-incrementing) bir alan yaratabilirim?
d789 1
a789 1
        id   SERIAL,
d806 5
a810 4
   4.15.2) SERIAL giriinin degerini nasl alabilirim?

  Bir yaklam, sequence nesnesindeki SERIAL deerini, veriyi girmeden nce nextval() ile alp, aldnz deeri 
kendinizin girmesidir. 4.15.1'deki rnek tabloyu kullanarak bir rnek verelim:
d815 4
a818 2
  Dier sorgular iin new_id'de yeni deerin saklanmas gerekir. Otomatik olarak yaratlan SEQUENE nesnesinin ad,
  <tablo ad>_<serial kolonu ad>_seq eklinde olacaktr (< > iaretleri olmadan).
d826 2
a827 2
  en az tanabilir zm olacaktr. Perl'de, Edmund Mergl'in DBD:Pg mdl ile birlikte DBI kullanarak, OID deeri
  $sth->execute() altrldktan sonra $sth->(pg_OID_status) ile alnabilir.
d841 20
a860 15

OIDler, tekil satr numaralarna PostgreSQL'in yantdr. PostgreSQL'de yaratlan her say, tekil bir OID alr. 
initdb ilemi srasnda yaratlan tm OID'ler 16384'ten kktr (backend/access/transam.h). Kullanclar tarafndan 
yaratlan tm OID'ler bu sayya eit ya da bu saydan byktr. Varsaylan durumda, tm bu OIDler sadece bir tablo ya 
da veritabannda deil, tm PostgreSQL kurulumunda tekildir.

PostgreSQL OIDleri, tablolar arasnda satrlar ilikilendirmek iin kendi i tablolarnda kullanr. Bu OIDler 
belirli kullanc satrlarn belirtmek iin kullanabilir ve join ilemlerinde kullanlr. OID deerlerini saklamak 
iin OID kolon tipini kullanmanz nerinir. Daha hzl bir eriim iin, OID alannda bir index yaratabilirsiniz.

OID'ler yeni satrlara, tm veritabanlar tarafnda kullanlan ortak bir alandan atanrlar. Eer OID'i baka bir 
deere eitlemek isterseniz ya da tablonun bir kopyasn orijinal OIDler ile karmak isterseniz, bu mmkndr:

        CREATE TABLE new_table(old_OID OID, mycol int);
        SELECT old_OID, mycol NTO new FROM old;
d863 1
a863 4
        COPY new WITH OIDS FROM '/tmp/pgtable';

OIDler 4-bit tamsay olarak saklanrlar ve 4 milyarda overflow olacaktr. Kimse bu sayya ulatna dair bir bilgi 
iletmedi ve bu snr kimse bu snra ulamadan kaldracaz.
d865 7
a871 2
TIDler, belirli fiziksel satrlar block ve offset deerleri ile belirtmekte kullanlr. TIDler, satrlar deitiinde 
ya da yeniden yklendiinde deiirler. Index girdileri tarafndan fiziksel satrlar gstermek iin kullanlrlar.
d875 1
a875 1
   Kaynak kodun bir ksm ve eski belgeler, daha geni kullanm alan olan terimleri
d895 3
a897 3
   Sisteminizde sanal belleinizi tketmis olabilirsiniz, ya da ekirdeiniz
   belli kaynaklar icin dk bir snra sahip olabilir. Postmaster'i balatmadan nce 
   aadakileri deneyebilirsiniz:
d904 3
a906 3
   saglayacaktr. Bu komut, varolan srece (current process) ve komut alstrldktan
   sonraki tm alt islemlere uygulanr. Eer SQL istemcinizle, backendin ok fazla veri 
   dndrmesi nedeniyle bir sorun yayorsanz, bunu istemciyi balatmadan nce deneyiniz.
d908 1
a908 1
       4.19) Hangi PostgreSQL srmn alstrdgm nasl grebilirim?
d910 1
a910 1
   psql arabiriminde, SELECT version(); yaznz.
d914 2
a915 2
   Large object ilemlerinizin ularna, yani  lo_open ... lo_close komutlarnn evresine, 
    BEGIN WORK ve COMMIT koymanz gerekmektedir.
d919 1
a919 1
   4.21) u andaki zaman ntanml deer olarak kabul eden kolonu nasl yaratabilirim?
d927 3
d931 1
a931 4
7.4 srmnden nce, subqueryler. Eer subquery sadece birka satr ve outer query bol sayda satr dndryorsa, IN 
en hzlsdr. Sorgular hzlandrmak iin IN yerine EXISTS kullann:

    SELECT *
d933 1
a933 1
    WHERE col IN (SELECT subcol FROM subtab);
d935 2
a936 3
sorgusunu, aadaki ile deitirin:

    SELECT *
d938 1
a938 1
    WHERE EXISTS (SELECT subcol FROM subtab WHERE subcol = col);
d940 1
a940 4
 Bunun hzl olabilmesi iin, subcol'un indekslenmi bir kolon olmas gerekmektedir.
 
	7.4 srm ve sonrasnda, IN aslnda normal sorgularla ayn karmak join tekniklerini kullanr ve EXISTS'e tercih 
	edilir.
d942 1
a942 1
       4.23) Outer join islemini nasl yapabilirim?
d944 2
a945 2
   PostgreSQL outer join ilemlerini SQL standartlarn kullanarak gerekletirmektedir.
   Aada 2 rnek bulunmaktadr:
d955 3
a957 3
   Bu zde sorgular t1.col ' i  t2.col'ye join ederler ve ayn zamanda t1'deki unjoined satrlar 
   (t2'de elenmenis olanlarla) dndrrler. RIGHT JON t2'nin unjoined satrlarn ekleyecektir.
   Bir FULL join, elemi btn satrlar ve t1 ile t2'den tm balanmam (unjoined) satrlar alr.
d973 2
a974 2
       4.24) Ayn anda birden fazla veritabannda nasl ilem yapabilirim?

d977 1
a977 1
   cross-database bir sorgunun nasl davranacagn kestirmek zordur.
d979 3
a981 3
   contrib/dblink fonksiyon arlarn kullanarak cross-database sorgulara izin vermektedir. Tabii ki, 
   bir istemci deiik veritabanlarna ayn anda eriim salayabilir ve bilgiyi bu sekilde
   birletirebilir.
d987 1
a987 1
	http://techdocs.postgresql.org/guides/SetReturningFunctions .
d989 1
a989 1
   4.26) Neden PL/pgSQL fonksiyonlar iinden gvenli bir ekilde tablo yaratma/kaldrma ilemlerini yapamyoruz?
d991 1
a991 1
   PL/pgSQL fonksiyon ierikleri cacheler. Bunun istenmeyen bir taraf, eer bir PL/pgSQL fonksiyonu geici bir
d994 1
a994 1
   geici tablo eriimleri iin PL/pgSQL'de EXECUTE kullanmaktr. Bu, sorgunun her seferinde yeniden ilenmesini
d1008 1
a1008 4
    * stemciden sunucuya iletiimi ifrelemek iin, sunucuda ssl seenei postgresql.conf iinde ak olmaldr.
      Ayrca,pg_hba.conf dosyas iinde host ya da hostssl kayd mutlaka olmaldr ve istemci sslmode 
      kapatlmamaldr. (Ayn zamanda,PostgreSQL'in doal SSL balantlar dnda ssh ya da ssl gibi 3.parti 
      ifrelenmi veri iletimi de mmkndr.)
d1010 1
a1010 1
      srmlerde, postgresql.conf iindeki PASSWORD_ENCRYPTION seeneini aktif hale getirmeniz gerekmektedir.
d1017 1
a1017 1
    5.1)  Kullanc-tanml bir fonksiyon yazdm. psql'de altrdm zaman neden core dump ediyor?
d1022 1
a1022 1
    5.2) PostgreSQL'e nasl yeni veri tipleri/fonksiyonlar ekleyebilirim?
d1024 1
a1024 1
   almalarnz pgsql-hackers e-posta listesine gnderiniz. Kodunuz incelendikten sonra
d1027 1
a1027 1
    5.3) Bir tuple dndrmek icin bir C fonksiyonunu nasl yazarm?
d1029 1
a1029 1
     PostgreSQL 7.3 srm ile birlikte, C, PL/pgSQL ve SQL kullanlarak tablo-dndren 
d1031 1
a1031 1
     bakabilirsiniz. Bir rnei contrib/tablefunc iinde bulabilirsiniz.
d1034 1
a1034 1
     geerli olmuyor. Neden?
@


1.1
log
@Add Turkish FAQ, from Devrim GUNDUZ.
@
text
@d1 3
d5 132
a136 101
   PostgreSQL iin Ska Sorulan Sorular (SSS) Son gncelleme : 19 Mays
   2003 Pazartesi - 03:05:21 Current maintainer: Bruce Momjian
   (pgman@@candle.pha.pa.us ) eviren : Devrim GNDZ (devrim@@gunduz.org )
   Nicolai Tufar (ntufar@@yahoo.com ) Bu belgenin en gncel hali,
   http://www.PostgreSQL.org/docs/faqs/FAQ_turkish.html ve
   http://www.gunduz.org/seminer/pg/FAQ_turkish adreslerinde grlebilir.
   Platforma zel sorularnz,http://www.PostgreSQL.org/docs/index.html
   adresinde yantlanr..
   ----------------------------------------------------------------------
   -- Genel Sorular 1.1 <#1.1>) PostgreSQL nedir? Nasl okunur? 1.2
   <#1.2>) PostgreSQL' in haklar nedir? 1.3 <#1.3>) PostgreSQL, hangi
   Unix platformlarnda alsr? 1.4 <#1.4>) Hangi Unix olmayan
   uyarlamalar bulunmaktadr? 1.5 <#1.5>) PostgreSQL'i nereden
   indirebilirim? 1.6 <#1.6>) Destei nereden alabilirim? 1.7 <#1.7>) En
   son srm nedir? 1.8 <#1.8>) Hangi belgelere ulasabilirim? 1.9
   <#1.9>) Bilinen hatalar ya da eksik zelliklere nereden ulasabilirim?
   1.10 <#1.10>) Nasl SQL renebilirim? 1.11 <#1.11>) PostgreSQL 2000
   ylna uyumlu mudur? 1.12 <#1.12>) Gelitirme takmna nasl
   katlabilirim?? 1.13 <#1.13>) Bir hata raporunu nasl gnderebilirim?
   1.14 <#1.14>) PostgreSQL, diger VTYS(DBMS lerle nasl
   karlatrlabilir? 1.15 <#1.15>) PostgreSQL'e maddi adan nasl
   destek olabilirim? Kullanc/istemci Sorular 2.1 <#2.1>) Are there
   ODBC drivers for PostgreSQL? 2.2 <#2.2>) What tools are available for
   using PostgreSQL with Web pages? 2.3 <#2.3>) Does PostgreSQL have a
   graphical user interface? 2.4 <#2.4>) What languages are available to
   communicate with PostgreSQL? Administrative Questions 3.1 <#3.1>) How
   do I install PostgreSQL somewhere other than //usr/local/pgsql/? 3.2
   <#3.2>) When I start /postmaster/, I get a /Bad System Call/ or core
   dumped message. Why? 3.3 <#3.3>) When I try to start /postmaster/, I
   get /IpcMemoryCreate/ errors. Why? 3.4 <#3.4>) When I try to start
   /postmaster/, I get /IpcSemaphoreCreate/ errors. Why? 3.5 <#3.5>) How
   do I control connections from other hosts? 3.6 <#3.6>) How do I tune
   the database engine for better performance? 3.7 <#3.7>) What debugging
   features are available? 3.8 <#3.8>) Why do I get /"Sorry, too many
   clients"/ when trying to connect? 3.9 <#3.9>) What is in the
   /pgsql_tmp/ directory? 3.10 <#3.10>) Why do I need to do a dump and
   restore to upgrade PostgreSQL releases? Operational Questions 4.1
   <#4.1>) What is the difference between binary cursors and normal
   cursors? 4.2 <#4.2>) How do I SELECT only the first few rows of a
   query? 4.3 <#4.3>) How do I get a list of tables or other things I can
   see in /psql/? 4.4 <#4.4>) How do you remove a column from a table?
   4.5 <#4.5>) What is the maximum size for a row, a table, and a
   database? 4.6 <#4.6>) How much database disk space is required to
   store data from a typical text file? 4.7 <#4.7>) How do I find out
   what tables, indexes, databases, and users are defined? 4.8 <#4.8>) My
   queries are slow or don't make use of the indexes. Why? 4.9 <#4.9>)
   How do I see how the query optimizer is evaluating my query? 4.10
   <#4.10>) What is an R-tree index? 4.11 <#4.11>) What is the Genetic
   Query Optimizer? 4.12 <#4.12>) How do I perform regular expression
   searches and case-insensitive regular expression searches? How do I
   use an index for case-insensitive searches? 4.13 <#4.13>) In a query,
   how do I detect if a field is NULL? 4.14 <#4.14>) What is the
   difference between the various character types? 4.15.1 <#4.15.1>) How
   do I create a serial/auto-incrementing field? 4.15.2 <#4.15.2>) How do
   I get the value of a SERIAL insert? 4.15.3 <#4.15.3>) Don't
   /currval()/ and /nextval()/ lead to a race condition with other users?
   4.15.4 <#4.15.4>) Why aren't my sequence numbers reused on transaction
   abort? Why are there gaps in the numbering of my sequence/SERIAL
   column? 4.16 <#4.16>) What is an OID? What is a TID? 4.17 <#4.17>)
   What is the meaning of some of the terms used in PostgreSQL? 4.18
   <#4.18>) Why do I get the error /"ERROR: Memory exhausted in
   AllocSetAlloc()"/? 4.19 <#4.19>) How do I tell what PostgreSQL version
   I am running? 4.20 <#4.20>) Why does my large-object operations get
   /"invalid large obj descriptor"/? 4.21 <#4.21>) How do I create a
   column that will default to the current time? 4.22 <#4.22>) Why are my
   subqueries using |IN| so slow? 4.23 <#4.23>) How do I perform an outer
   join? 4.24 <#4.24>) How do I perform queries using multiple databases?
   4.25 <#4.25>) How do I return multiple rows or columns from a
   function? 4.26 <#4.26>) Why can't I reliably create/drop temporary
   tables in PL/PgSQL functions? 4.27 <#4.27>) What replication options
   are available? 4.28 <#4.28>) What encryption options are available?
   Extending PostgreSQL 5.1 <#5.1>) I wrote a user-defined function. When
   I run it in /psql/, why does it dump core? 5.2 <#5.2>) How can I
   contribute some nifty new types and functions to PostgreSQL? 5.3
   <#5.3>) How do I write a C function to return a tuple? 5.4 <#5.4>) I
   have changed a source file. Why does the recompile not see the change?
   ----------------------------------------------------------------------
   -- General Questions 1.1) What is PostgreSQL? How is it pronounced?
   PostgreSQL is pronounced /Post-Gres-Q-L/. PostgreSQL is an enhancement
   of the POSTGRES database management system, a next-generation DBMS
   research prototype. While PostgreSQL retains the powerful data model
   and rich data types of POSTGRES, it replaces the PostQuel query
   language with an extended subset of SQL. PostgreSQL is free and the
   complete source is available. PostgreSQL development is performed by a
   team of developers who all subscribe to the PostgreSQL development
   mailing list. The current coordinator is Marc G. Fournier
   (scrappy@@PostgreSQL.org ). (See section 1.6 <#1.6> on how to join).
   This team is now responsible for all development of PostgreSQL. The
   authors of PostgreSQL 1.01 were Andrew Yu and Jolly Chen. Many others
   have contributed to the porting, testing, debugging, and enhancement
   of the code. The original Postgres code, from which PostgreSQL is
   derived, was the effort of many graduate students, undergraduate
   students, and staff programmers working under the direction of
   Professor Michael Stonebraker at the University of California,
   Berkeley. The original name of the software at Berkeley was Postgres.
   When SQL functionality was added in 1995, its name was changed to
   Postgres95. The name was changed at the end of 1996 to PostgreSQL.
   1.2) What is the copyright on PostgreSQL? PostgreSQL is subject to the
   following COPYRIGHT: PostgreSQL Data Base Management System Portions
   copyright (c) 1996-2002, PostgreSQL Global Development Group Portions
   Copyright (c) 1994-6 Regents of the University of California
d141 135
a275 75
   copies. IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO
   ANY PARTY FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
   DAMAGES, INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS
   SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF CALIFORNIA
   HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. THE UNIVERSITY OF
   CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT
   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
   A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON AN "AS IS"
   BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE
   MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. The
   above is the BSD license, the classic open-source license. It has no
   restrictions on how the source code may be used. We like it and have
   no intention of changing it. 1.3) What Unix platforms does PostgreSQL
   run on? In general, a modern Unix-compatible platform should be able
   to run PostgreSQL. The platforms that had received explicit testing at
   the time of release are listed in the installation instructions. 1.4)
   What non-Unix ports are available? *Client* It is possible to compile
   the /libpq/ C library, psql, and other interfaces and client
   applications to run on MS Windows platforms. In this case, the client
   is running on MS Windows, and communicates via TCP/IP to a server
   running on one of our supported Unix platforms. A file /win32.mak/ is
   included in the distribution for making a Win32 /libpq/ library and
   /psql/. PostgreSQL also communicates with ODBC clients. *Server* The
   database server can run on Windows NT and Win2k using Cygwin, the
   Cygnus Unix/NT porting library. See /pgsql/doc/FAQ_MSWIN/ in the
   distribution or the MS Windows FAQ at
   http://www.PostgreSQL.org/docs/faqs/text/FAQ_MSWIN
   www.PostgreSQL.org/docs/faqs/text/FAQ_MSWIN>. A native port to MS Win
   NT/2000/XP is currently being worked on. For more details on the
   current status of PostgreSQL on Windows see
   http://techdocs.postgresql.org/guides/Windows
   techdocs.postgresql.org/guides/Windows>. There is also a Novell
   Netware 6 port at http://forge.novell.com. 1.5) Where can I get
   PostgreSQL? The primary anonymous ftp site for PostgreSQL is
   ftp://ftp.PostgreSQL.org/pub. For mirror sites, see our main web site.
   1.6) Where can I get support? The main mailing list is:
   pgsql-general@@PostgreSQL.org . It is available for discussion of
   matters pertaining to PostgreSQL. To subscribe, send mail with the
   following lines in the body (not the subject line): subscribe end to
   pgsql-general-request@@PostgreSQL.org . There is also a digest list
   available. To subscribe to this list, send email to:
   pgsql-general-digest-request@@PostgreSQL.org with a body of: subscribe
   end Digests are sent out to members of this list whenever the main
   list has received around 30k of messages. The bugs mailing list is
   available. To subscribe to this list, send email to
   pgsql-bugs-request@@PostgreSQL.org with a body of: subscribe end There
   is also a developers discussion mailing list available. To subscribe
   to this list, send email to pgsql-hackers-request@@PostgreSQL.org with
   a body of: subscribe end Additional mailing lists and information
   about PostgreSQL can be found via the PostgreSQL WWW home page at:
   http://www.PostgreSQL.org There is also an IRC channel on EFNet and
   OpenProjects, channel /#PostgreSQL/. I use the Unix command |irc -c
   '#PostgreSQL' "$USER" irc.phoenix.net.| A list of commercial support
   companies is available at
   http://www.ca.PostgreSQL.org/users-lounge/commercial-support.html.
   1.7) What is the latest release? The latest release of PostgreSQL is
   version 7.3.3. We plan to have major releases every four months. 1.8)
   What documentation is available? Several manuals, manual pages, and
   some small test examples are included in the distribution. See the
   //doc/ directory. You can also browse the manuals online at
   http://www.PostgreSQL.org/docs. There are two PostgreSQL books
   available online at http://www.PostgreSQL.org/docs/awbook.html and
   http://www.commandprompt.com/ppbook/. There is a list of PostgreSQL
   books available for purchase at http://www.ca.PostgreSQL.org/books/.
   There is also a collection of PostgreSQL technical articles at
   http://techdocs.PostgreSQL.org/. /psql/ has some nice \d commands to
   show information about types, operators, functions, aggregates, etc.
   Our web site contains even more documentation. 1.9) How do I find out
   about known bugs or missing features? PostgreSQL supports an extended
   subset of SQL-92. See our TODO developer.PostgreSQL.org/todo.php> list
   for known bugs, missing features, and future plans. 1.10) How can I
   learn SQL? The PostgreSQL book at
   http://www.PostgreSQL.org/docs/awbook.html teaches SQL. There is
   another PostgreSQL book at http://www.commandprompt.com/ppbook.
   www.commandprompt.com/ppbook/> There is a nice tutorial at
d277 309
a585 237
   www.intermedia.net/support/sql/sqltut.shtm> at
   http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM,
   ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM> and at
   http://sqlcourse.com. sqlcourse.com/> Another one is "Teach Yourself
   SQL in 21 Days, Second Edition" at
   http://members.tripod.com/er4ebus/sql/index.htm Many of our users like
   /The Practical SQL Handbook/, Bowman, Judith S., et al.,
   Addison-Wesley. Others like /The Complete Reference SQL/, Groff et
   al., McGraw-Hill. 1.11) Is PostgreSQL Y2K compliant? Yes, we easily
   handle dates past the year 2000 AD, and before 2000 BC. 1.12) How do I
   join the development team? First, download the latest source and read
   the PostgreSQL Developers documentation on our web site, or in the
   distribution. Second, subscribe to the /pgsql-hackers/ and
   /pgsql-patches/ mailing lists. Third, submit high quality patches to
   pgsql-patches. There are about a dozen people who have commit
   privileges to the PostgreSQL CVS archive. They each have submitted so
   many high-quality patches that it was impossible for the existing
   committers to keep up, and we had confidence that patches they
   committed were of high quality. 1.13) How do I submit a bug report?
   Please visit the PostgreSQL BugTool page at
   http://www.PostgreSQL.org/bugs/bugs.php, which gives guidelines and
   directions on how to submit a bug report. Also check out our ftp site
   ftp://ftp.PostgreSQL.org/pub to see if there is a more recent
   PostgreSQL version or patches. 1.14) How does PostgreSQL compare to
   other DBMSs? There are several ways of measuring software: features,
   performance, reliability, support, and price. *Features* PostgreSQL
   has most features present in large commercial DBMSs, like
   transactions, subselects, triggers, views, foreign key referential
   integrity, and sophisticated locking. We have some features they do
   not have, like user-defined types, inheritance, rules, and
   multi-version concurrency control to reduce lock contention.
   *Performance* PostgreSQL has performance similar to other commercial
   and open source databases. it is faster for some things, slower for
   others. In comparison to MySQL or leaner database systems, we are
   slower on inserts/updates because of transaction overhead. Of course,
   MySQL does not have any of the features mentioned in the /Features/
   section above. We are built for reliability and features, though we
   continue to improve performance in every release. There is an
   interesting Web page comparing PostgreSQL to MySQL at
   http://openacs.org/philosophy/why-not-mysql.html
   openacs.org/philosophy/why-not-mysql.html> *Reliability* We realize
   that a DBMS must be reliable, or it is worthless. We strive to release
   well-tested, stable code that has a minimum of bugs. Each release has
   at least one month of beta testing, and our release history shows that
   we can provide stable, solid releases that are ready for production
   use. We believe we compare favorably to other database software in
   this area. *Support* Our mailing lists provide contact with a large
   group of developers and users to help resolve any problems
   encountered. While we cannot guarantee a fix, commercial DBMSs do not
   always supply a fix either. Direct access to developers, the user
   community, manuals, and the source code often make PostgreSQL support
   superior to other DBMSs. There is commercial per-incident support
   available for those who need it. (See FAQ section 1.6 <#1.6>.) *Price*
   We are free for all use, both commercial and non-commercial. You can
   add our code to your product with no limitations, except those
   outlined in our BSD-style license stated above. 1.15) How can I
   financially assist PostgreSQL? PostgreSQL has had a first-class
   infrastructure since we started in 1996. This is all thanks to Marc
   Fournier, who has created and managed this infrastructure over the
   years. Quality infrastructure is very important to an open-source
   project. It prevents disruptions that can greatly delay forward
   movement of the project. Of course, this infrastructure is not cheap.
   There are a variety of monthly and one-time expenses that are required
   to keep it going. If you or your company has money it can donate to
   help fund this effort, please go to http://store.pgsql.com/shopping/
   and make a donation. Although the web page mentions PostgreSQL, Inc,
   the "contributions" item is solely to support the PostgreSQL project
   and does not fund any specific company. If you prefer, you can also
   send a check to the contact address.
   ----------------------------------------------------------------------
   -- User Client Questions 2.1) Are there ODBC drivers for PostgreSQL?
   There are two ODBC drivers available, PsqlODBC and OpenLink ODBC. You
   can download PsqlODBC from
   http://gborg.postgresql.org/project/psqlodbc/projdisplay.php
   gborg.postgresql.org/project/psqlodbc/projdisplay.php>. OpenLink ODBC
   can be gotten from http://www.openlinksw.com www.openlinksw.com/>. It
   works with their standard ODBC client software so you'll have
   PostgreSQL ODBC available on every client platform they support (Win,
   Mac, Unix, VMS). They will probably be selling this product to people
   who need commercial-quality support, but a freeware version will
   always be available. Please send questions to
   postgres95@@openlink.co.uk . 2.2) What tools are available for using
   PostgreSQL with Web pages? A nice introduction to Database-backed Web
   pages can be seen at: http://www.webreview.com For Web integration,
   PHP is an excellent interface. It is at http://www.php.net. For
   complex cases, many use the Perl interface and CGI.pm or mod_perl.
   2.3) Does PostgreSQL have a graphical user interface? Yes, there are
   several graphical interfaces to PostgreSQL available. These include
   PgAccess http://www.pgaccess.org www.pgaccess.org>), PgAdmin II
   (http://www.pgadmin.org, Win32-only), RHDB Admin
   (http://sources.redhat.com/rhdb/ ) and Rekall (
   http://www.thekompany.com/products/rekall/
   www.thekompany.com/products/rekall/>, proprietary). There is also
   PHPPgAdmin ( http://phppgadmin.sourceforge.net/
   phppgadmin.sourceforge.net/>), a web-based interface to PostgreSQL.
   See http://techdocs.postgresql.org/guides/GUITools for a more detailed
   list. 2.4) What languages are able to communicate with PostgreSQL?
   Most popular programming languages contain an interface to PostgreSQL.
   Check your programming language's list of extension modules. The
   following interfaces are included in the PostgreSQL distribution: * C
   (libpq) * Embedded C (ecpg) * Java (jdbc) * Python (PyGreSQL) * TCL
   (libpgtcl) Additional interfaces are available at
   http://gborg.postgresql.org in the /Drivers/Interfaces/ section.
   ----------------------------------------------------------------------
   -- Administrative Questions 3.1) How do I install PostgreSQL somewhere
   other than //usr/local/pgsql/? Specify the /--prefix/ option when
   running /configure/. 3.2) When I start /postmaster/, I get a /Bad
   System Call/ or core dumped message. Why? It could be a variety of
   problems, but first check to see that you have System V extensions
   installed in your kernel. PostgreSQL requires kernel support for
   shared memory and semaphores. 3.3) When I try to start /postmaster/, I
   get /IpcMemoryCreate/ errors. Why? You either do not have shared
   memory configured properly in your kernel or you need to enlarge the
   shared memory available in the kernel. The exact amount you need
   depends on your architecture and how many buffers and backend
   processes you configure for /postmaster/. For most systems, with
   default numbers of buffers and processes, you need a minimum of ~1 MB.
   See the PostgreSQL Administrator's Guide
   www.PostgreSQL.org/docs/view.php?version=current&idoc=1&file=kernel-re
   sources.html> for more detailed information about shared memory and
   semaphores. 3.4) When I try to start /postmaster/, I get
   /IpcSemaphoreCreate/ errors. Why? If the error message is
   /IpcSemaphoreCreate: semget failed (No space left on device)/ then
   your kernel is not configured with enough semaphores. Postgres needs
   one semaphore per potential backend process. A temporary solution is
   to start /postmaster/ with a smaller limit on the number of backend
   processes. Use /-N/ with a parameter less than the default of 32. A
   more permanent solution is to increase your kernel's SEMMNS and SEMMNI
   parameters. Inoperative semaphores can also cause crashes during heavy
   database access. If the error message is something else, you might not
   have semaphore support configured in your kernel at all. See the
   PostgreSQL Administrator's Guide for more detailed information about
   shared memory and semaphores. 3.5) How do I control connections from
   other hosts? By default, PostgreSQL only allows connections from the
   local machine using Unix domain sockets. Other machines will not be
   able to connect unless you add the /-i/ flag to /postmaster/, *and*
   enable host-based authentication by modifying the file
   /$PGDATA/pg_hba.conf/ accordingly. This will allow TCP/IP connections.
   3.6) How do I tune the database engine for better performance?
   Certainly, indexes can speed up queries. The EXPLAIN command allows
   you to see how PostgreSQL is interpreting your query, and which
   indexes are being used. If you are doing many INSERTs, consider doing
   them in a large batch using the COPY command. This is much faster than
   individual INSERTS. Second, statements not in a BEGIN WORK/COMMIT
   transaction block are considered to be in their own transaction.
   Consider performing several statements in a single transaction block.
   This reduces the transaction overhead. Also, consider dropping and
   recreating indexes when making large data changes. There are several
   tuning options. You can disable /fsync()/ by starting /postmaster/
   with a /-o -F/ option. This will prevent /fsync()/s from flushing to
   disk after every transaction. You can also use the /postmaster/ /-B/
   option to increase the number of shared memory buffers used by the
   backend processes. If you make this parameter too high, the
   /postmaster/ may not start because you have exceeded your kernel's
   limit on shared memory space. Each buffer is 8K and the default is 64
   buffers. You can also use the backend /-S/ option to increase the
   maximum amount of memory used by the backend process for temporary
   sorts. The /-S/ value is measured in kilobytes, and the default is 512
   (i.e. 512K). You can also use the CLUSTER command to group data in
   tables to match an index. See the CLUSTER manual page for more
   details. 3.7) What debugging features are available? PostgreSQL has
   several features that report status information that can be valuable
   for debugging purposes. First, by running /configure/ with the
   --enable-cassert option, many /assert()/s monitor the progress of the
   backend and halt the program when something unexpected occurs. Both
   /postmaster/ and /postgres/ have several debug options available.
   First, whenever you start /postmaster/, make sure you send the
   standard output and error to a log file, like: cd /usr/local/pgsql
   ./bin/postmaster >server.log 2>&1 & This will put a server.log file in
   the top-level PostgreSQL directory. This file contains useful
   information about problems or errors encountered by the server.
   /Postmaster/ has a /-d/ option that allows even more detailed
   information to be reported. The /-d/ option takes a number that
   specifies the debug level. Be warned that high debug level values
   generate large log files. If /postmaster/ is not running, you can
   actually run the /postgres/ backend from the command line, and type
   your SQL statement directly. This is recommended *only* for debugging
   purposes. Note that a newline terminates the query, not a semicolon.
   If you have compiled with debugging symbols, you can use a debugger to
   see what is happening. Because the backend was not started from
   /postmaster/, it is not running in an identical environment and
   locking/backend interaction problems may not be duplicated. If
   /postmaster/ is running, start /psql/ in one window, then find the PID
   of the /postgres/ process used by /psql/. Use a debugger to attach to
   the /postgres/ PID. You can set breakpoints in the debugger and issue
   queries from /psql/. If you are debugging /postgres/ startup, you can
   set PGOPTIONS="-W n", then start /psql/. This will cause startup to
   delay for /n/ seconds so you can attach to the process with the
   debugger, set any breakpoints, and continue through the startup
   sequence. The /postgres/ program has /-s, -A/, and /-t/ options that
   can be very useful for debugging and performance measurements. You can
   also compile with profiling to see what functions are taking execution
   time. The backend profile files will be deposited in the
   /pgsql/data/base/dbname/ directory. The client profile file will be
   put in the client's current directory. Linux requires a compile with
   /-DLINUX_PROFILE/ for proper profiling. 3.8) Why do I get /"Sorry, too
   many clients"/ when trying to connect? You need to increase
   /postmaster/'s limit on how many concurrent backend processes it can
   start. The default limit is 32 processes. You can increase it by
   restarting /postmaster/ with a suitable /-N/ value or modifying
   /postgresql.conf/. Note that if you make /-N/ larger than 32, you must
   also increase /-B/ beyond its default of 64; /-B/ must be at least
   twice /-N/, and probably should be more than that for best
   performance. For large numbers of backend processes, you are also
   likely to find that you need to increase various Unix kernel
   configuration parameters. Things to check include the maximum size of
   shared memory blocks, SHMMAX; the maximum number of semaphores, SEMMNS
   and SEMMNI; the maximum number of processes, NPROC; the maximum number
   of processes per user, MAXUPRC; and the maximum number of open files,
   NFILE and NINODE. The reason that PostgreSQL has a limit on the number
   of allowed backend processes is so your system won't run out of
   resources. 3.9) What is in the /pgsql_tmp/ directory? This directory
   contains temporary files generated by the query executor. For example,
   if a sort needs to be done to satisfy an ORDER BY and the sort
   requires more space than the backend's /-S/ parameter allows, then
   temporary files are created here to hold the extra data. The temporary
   files are usually deleted automatically, but might remain if a backend
   crashes during a sort. A stop and restart of the /postmaster/ will
   remove files from those directories. 3.10) Why do I need to do a dump
   and restore to upgrade between major PostgreSQL releases? The
   PostgreSQL team makes only small changes between minor releases, so
   upgrading from 7.2 to 7.2.1 does not require a dump and restore.
   However, major releases (e.g. from 7.2 to 7.3) often change the
   internal format of system tables and data files. These changes are
   often complex, so we don't maintain backward compatability for data
   files. A dump outputs data in a generic format that can then be loaded
   in using the new internal format. In releases where the on-disk format
   does not change, the /pg_upgrade/ script can be used to upgrade
   without a dump/restore. The release notes mention whether /pg_upgrade/
   is available for the release.
   ----------------------------------------------------------------------
   -- Operational Questions 4.1) What is the difference between binary
   cursors and normal cursors? See the DECLARE manual page for a
   description. 4.2) How do I SELECT only the first few rows of a query?
   See the FETCH manual page, or use SELECT ... LIMIT.... The entire
   query may have to be evaluated, even if you only want the first few
   rows. Consider using a query that has an ORDER BY. If there is an
d588 281
a868 182
   be evaluated until the desired rows have been generated. 4.3) How do I
   get a list of tables or other things I can see in /psql/? You can read
   the source code for /psql/ in file /pgsql/src/bin/psql/describe.c/. It
   contains SQL commands that generate the output for psql's backslash
   commands. You can also start /psql/ with the /-E/ option so it will
   print out the queries it uses to execute the commands you give. 4.4)
   How do you remove a column from a table? This functionality was added
   in release 7.3 with ALTER TABLE DROP COLUMN. In earlier versions, you
   can do this: BEGIN; LOCK TABLE old_table; SELECT ... -- select all
   columns but the one you want to remove INTO TABLE new_table FROM
   old_table; DROP TABLE old_table; ALTER TABLE new_table RENAME TO
   old_table; COMMIT; 4.5) What is the maximum size for a row, a table,
   and a database? These are the limits: Maximum size for a database?
   unlimited (4 TB databases exist) Maximum size for a table? 16 TB
   Maximum size for a row? 1.6TB Maximum size for a field? 1 GB Maximum
   number of rows in a table? unlimited Maximum number of columns in a
   table? 250-1600 depending on column types Maximum number of indexes on
   a table? unlimited Of course, these are not actually unlimited, but
   limited to available disk space and memory/swap space. Performance may
   suffer when these values get unusually large. The maximum table size
   of 16 TB does not require large file support from the operating
   system. Large tables are stored as multiple 1 GB files so file system
   size limits are not important. The maximum table size and maximum
   number of columns can be increased if the default block size is
   increased to 32k. 4.6) How much database disk space is required to
   store data from a typical text file? A PostgreSQL database may require
   up to five times the disk space to store data from a text file. As an
   example, consider a file of 100,000 lines with an integer and text
   description on each line. Suppose the text string avergages twenty
   bytes in length. The flat file would be 2.8 MB. The size of the
   PostgreSQL database file containing this data can be estimated as 6.4
   MB: 36 bytes: each row header (approximate) 24 bytes: one int field
   and one text field + 4 bytes: pointer on page to tuple
   ---------------------------------------- 64 bytes per row The data
   page size in PostgreSQL is 8192 bytes (8 KB), so: 8192 bytes per page
   ------------------- = 128 rows per database page (rounded down) 64
   bytes per row 100000 data rows -------------------- = 782 database
   pages (rounded up) 128 rows per page 782 database pages * 8192 bytes
   per page = 6,406,144 bytes (6.4 MB) Indexes do not require as much
   overhead, but do contain the data that is being indexed, so they can
   be large also. NULLs are stored in bitmaps, so they use very little
   space. 4.7) How do I find out what tables, indexes, databases, and
   users are defined? /psql/ has a variety of backslash commands to show
   such information. Use \? to see them. There are also system tables
   beginning with /pg_/ that describe these too. Also, /psql -l/ will
   list all databases. Also try the file
   /pgsql/src/tutorial/syscat.source/. It illustrates many of the SELECTs
   needed to get information from the database system tables. 4.8) My
   queries are slow or don't make use of the indexes. Why? Indexes are
   not automatically used by every query. Indexes are only used if the
   table is larger than a minimum size, and the query selects only a
   small percentage of the rows in the table. This is because the random
   disk access caused by an index scan can be slower than a straight read
   through the table, or sequential scan. To determine if an index should
   be used, PostgreSQL must have statistics about the table. These
   statistics are collected using VACUUM ANALYZE, or simply ANALYZE.
   Using statistics, the optimizer knows how many rows are in the table,
   and can better determine if indexes should be used. Statistics are
   also valuable in determining optimal join order and join methods.
   Statistics collection should be performed periodically as the contents
   of the table change. Indexes are normally not used for ORDER BY or to
   perform joins. A sequential scan followed by an explicit sort is
   usually faster than an index scan of a large table. However, LIMIT
   combined with ORDER BY often will use an index because only a small
   portion of the table is returned. In fact, though MAX() and MIN()
   don't use indexes, it is possible to retrieve such values using an
   index with ORDER BY and LIMIT: SELECT col FROM tab ORDER BY col [ DESC
   ] LIMIT 1; If you believe the optimizer is incorrect in choosing a
   sequential scan, use |SET enable_seqscan TO 'off'| and run tests to
   see if an index scan is indeed faster. When using wild-card operators
   such as LIKE or /~/, indexes can only be used in certain
   circumstances: * The beginning of the search string must be anchored
   to the start of the string, i.e. o LIKE patterns must not start with
   /%/. o /~/ (regular expression) patterns must start with /^/. * The
   search string can not start with a character class, e.g. [a-e]. *
   Case-insensitive searches such as ILIKE and /~*/ do not utilise
   indexes. Instead, use functional indexes, which are described in
   section 4.12 <#4.12>. * The default /C/ locale must be used during
   /initdb/. 4.9) How do I see how the query optimizer is evaluating my
   query? See the EXPLAIN manual page. 4.10) What is an R-tree index? An
   R-tree index is used for indexing spatial data. A hash index can't
   handle range searches. A B-tree index only handles range searches in a
   single dimension. R-trees can handle multi-dimensional data. For
   example, if an R-tree index can be built on an attribute of type
   /point/, the system can more efficiently answer queries such as
   "select all points within a bounding rectangle." The canonical paper
   that describes the original R-tree design is: 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. You can also find
   this paper in Stonebraker's "Readings in Database Systems". Built-in
   R-trees can handle polygons and boxes. In theory, R-trees can be
   extended to handle higher number of dimensions. In practice, extending
   R-trees requires a bit of work and we don't currently have any
   documentation on how to do it. 4.11) What is the Genetic Query
   Optimizer? The GEQO module speeds query optimization when joining many
   tables by means of a Genetic Algorithm (GA). It allows the handling of
   large join queries through nonexhaustive search. 4.12) How do I
   perform regular expression searches and case-insensitive regular
   expression searches? How do I use an index for case-insensitive
   searches? The /~/ operator does regular expression matching, and /~*/
   does case-insensitive regular expression matching. The
   case-insensitive variant of LIKE is called ILIKE. Case-insensitive
   equality comparisons are normally expressed as: SELECT * FROM tab
   WHERE lower(col) = 'abc'; This will not use an standard index.
   However, if you create a functional index, it will be used: CREATE
   INDEX tabindex ON tab (lower(col)); 4.13) In a query, how do I detect
   if a field is NULL? You test the column with IS NULL and IS NOT NULL.
   4.14) What is the difference between the various character types? Type
   Internal Name Notes --------------------------------------------------
   VARCHAR(n) varchar size specifies maximum length, no padding CHAR(n)
   bpchar blank padded to the specified fixed length TEXT text no
   specific upper limit on length BYTEA bytea variable-length byte array
   (null-byte safe) "char" char one character You will see the internal
   name when examining system catalogs and in some error messages. The
   first four types above are "varlena" types (i.e., the first four bytes
   on disk are the length, followed by the data). Thus the actual space
   used is slightly greater than the declared size. However, these data
   types are also subject to compression or being stored out-of-line by
   TOAST, so the space on disk might also be less than expected.
   VARCHAR(n) is best when storing variable-length strings and it limits
   how long a string can be. TEXT is for strings of unlimited length,
   with a maximum of one gigabyte. CHAR(n) is for storing strings that
   are all the same length. CHAR(n) pads with blanks to the specified
   length, while VARCHAR(n) only stores the characters supplied. BYTEA is
   for storing binary data, particularly values that include NULL bytes.
   All the types described here have similar performance characteristics.
   4.15.1) How do I create a serial/auto-incrementing field? PostgreSQL
   supports a SERIAL data type. It auto-creates a sequence and index on
   the column. For example, this: CREATE TABLE person ( id SERIAL, name
   TEXT ); is automatically translated into this: 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 ); See the /create_sequence/ manual page
   for more information about sequences. You can also use each row's
   /OID/ field as a unique value. However, if you need to dump and reload
   the database, you need to use /pg_dump/'s /-o/ option or COPY WITH
   OIDS option to preserve the OIDs. 4.15.2) How do I get the value of a
   SERIAL insert? One approach is to retrieve the next SERIAL value from
   the sequence object with the /nextval()/ function /before/ inserting
   and then insert it explicitly. Using the example table in 4.15.1
   <#4.15.1>, an example in a pseudo-language would look like this:
   new_id = execute("SELECT nextval('person_id_seq')"); execute("INSERT
   INTO person (id, name) VALUES (new_id, 'Blaise Pascal')"); You would
   then also have the new value stored in |new_id| for use in other
   queries (e.g., as a foreign key to the |person| table). Note that the
   name of the automatically created SEQUENCE object will be named
   __/seq/, where /table/ and /serialcolumn/ are the names of your table
   and your SERIAL column, respectively. Alternatively, you could
   retrieve the assigned SERIAL value with the /currval()/ function
   /after/ it was inserted by default, e.g., execute("INSERT INTO person
   (name) VALUES ('Blaise Pascal')"); new_id = execute("SELECT
   currval('person_id_seq')"); Finally, you could use the OID <#4.16>
   returned from the INSERT statement to look up the default value,
   though this is probably the least portable approach. In Perl, using
   DBI with Edmund Mergl's DBD::Pg module, the oid value is made
   available via /$sth->{pg_oid_status}/ after /$sth->execute()/. 4.15.3)
   Don't /currval()/ and /nextval()/ lead to a race condition with other
   users? No. /currval()/ returns the current value assigned by your
   backend, not by all users. 4.15.4) Why aren't my sequence numbers
   reused on transaction abort? Why are there gaps in the numbering of my
   sequence/SERIAL column? To improve concurrency, sequence values are
   given out to running transactions as needed and are not locked until
   the transaction completes. This causes gaps in numbering from aborted
   transactions. 4.16) What is an OID? What is a TID? OIDs are
   PostgreSQL's answer to unique row ids. Every row that is created in
   PostgreSQL gets a unique OID. All OIDs generated during /initdb/ are
   less than 16384 (from /include/access/transam.h/). All user-created
   OIDs are equal to or greater than this. By default, all these OIDs are
   unique not only within a table or database, but unique within the
   entire PostgreSQL installation. PostgreSQL uses OIDs in its internal
   system tables to link rows between tables. These OIDs can be used to
   identify specific user rows and used in joins. It is recommended you
   use column type OID to store OID values. You can create an index on
   the OID field for faster access. OIDs are assigned to all new rows
   from a central area that is used by all databases. If you want to
   change the OID to something else, or if you want to make a copy of the
   table, with the original OIDs, there is no reason you can't do it:
   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'; OIDs are stored as 4-byte integers,
   and will overflow at 4 billion. No one has reported this ever
   happening, and we plan to have the limit removed before anyone does.
d870 171
a1040 105
   values. TIDs change after rows are modified or reloaded. They are used
   by index entries to point to physical rows. 4.17) What is the meaning
   of some of the terms used in PostgreSQL? Some of the source code and
   older documentation use terms that have more common usage. Here are
   some: * table, relation, class * row, record, tuple * column, field,
   attribute * retrieve, select * replace, update * append, insert * OID,
   serial value * portal, cursor * range variable, table name, table
   alias A list of general database terms can be found at:
   http://hea-www.harvard.edu/MST/simul/software/docs/pkgs/pgsql/glossary
   /glossary.html 4.18) Why do I get the error /"ERROR: Memory exhausted
   in AllocSetAlloc()"/? You probably have run out of virtual memory on
   your system, or your kernel has a low limit for certain resources. Try
   this before starting /postmaster/: ulimit -d 262144 limit datasize
   256m Depending on your shell, only one of these may succeed, but it
   will set your process data segment limit much higher and perhaps allow
   the query to complete. This command applies to the current process,
   and all subprocesses created after the command is run. If you are
   having a problem with the SQL client because the backend is returning
   too much data, try it before starting the client. 4.19) How do I tell
   what PostgreSQL version I am running? From /psql/, type |SELECT
   version();| 4.20) Why does my large-object operations get /"invalid
   large obj descriptor"/? You need to put |BEGIN WORK| and |COMMIT|
   around any use of a large object handle, that is, surrounding
   |lo_open| ... |lo_close.| Currently PostgreSQL enforces the rule by
   closing large object handles at transaction commit. So the first
   attempt to do anything with the handle will draw /invalid large obj
   descriptor/. So code that used to work (at least most of the time)
   will now generate that error message if you fail to use a transaction.
   If you are using a client interface like ODBC you may need to set
   |auto-commit off.| 4.21) How do I create a column that will default to
   the current time? Use /CURRENT_TIMESTAMP/: |CREATE TABLE test (x int,
   modtime timestamp DEFAULT CURRENT_TIMESTAMP ); | 4.22) Why are my
   subqueries using |IN| so slow? Currently, we join subqueries to outer
   queries by sequentially scanning the result of the subquery for each
   row of the outer query. If the subquery returns only a few rows and
   the outer query returns many rows, |IN| is fastest. To speed up other
   queries, replace |IN| with |EXISTS|: SELECT * FROM tab WHERE col IN
   (SELECT subcol FROM subtab); to: SELECT * FROM tab WHERE EXISTS
   (SELECT subcol FROM subtab WHERE subcol = col); For this to be fast,
   |subcol| should be an indexed column. This preformance problem will be
   fixed in 7.4. 4.23) How do I perform an outer join? PostgreSQL
   supports outer joins using the SQL standard syntax. Here are two
   examples: SELECT * FROM t1 LEFT OUTER JOIN t2 ON (t1.col = t2.col); or
   SELECT * FROM t1 LEFT OUTER JOIN t2 USING (col); These identical
   queries join t1.col to t2.col, and also return any unjoined rows in t1
   (those with no match in t2). A RIGHT join would add unjoined rows of
   t2. A FULL join would return the matched rows plus all unjoined rows
   from t1 and t2. The word OUTER is optional and is assumed in LEFT,
   RIGHT, and FULL joins. Ordinary joins are called INNER joins. In
   previous releases, outer joins can be simulated using UNION and NOT
   IN. For example, when joining /tab1/ and /tab2/, the following query
   does an /outer/ join of the two tables: SELECT tab1.col1, tab2.col2
   FROM tab1, tab2 WHERE tab1.col1 = tab2.col1 UNION ALL SELECT
   tab1.col1, NULL FROM tab1 WHERE tab1.col1 NOT IN (SELECT tab2.col1
   FROM tab2) ORDER BY col1 4.24) How do I perform queries using multiple
   databases? There is no way to query a database other than the current
   one. Because PostgreSQL loads database-specific system catalogs, it is
   uncertain how a cross-database query should even behave.
   /contrib/dblink/ allows cross-database queries using function calls.
   Of course, a client can make simultaneous connections to different
   databases and merge the results on the client side. 4.25) How do I
   return multiple rows or columns from a function? In 7.3, you can
   easily return multiple rows or columns from a function,
   http://techdocs.postgresql.org/guides/SetReturningFunctions
   techdocs.postgresql.org/guides/SetReturningFunctions>. 4.26) Why can't
   I reliably create/drop temporary tables in PL/PgSQL functions?
   PL/PgSQL caches function contents, and an unfortunate side effect is
   that if a PL/PgSQL function accesses a temporary table, and that table
   is later dropped and recreated, and the function called again, the
   function will fail because the cached function contents still point to
   the old temporary table. The solution is to use EXECUTE for temporary
   table access in PL/PgSQL. This will cause the query to be reparsed
   every time. 4.27) What replication options are available? There are
   several master/slave replication options available. These allow only
   the master to make database changes and the slave can only do database
   reads. The bottom of
   http://gborg.PostgreSQL.org/genpage?replication_research
   gborg.PostgreSQL.org/genpage?replication_research> lists them. A
   multi-master replication solution is being worked on at
   http://gborg.PostgreSQL.org/project/pgreplication/projdisplay.php.
   4.28) What encryption options are available? * /contrib/pgcrypto/
   contains many encryption functions for use in SQL queries. * The only
   way to encrypt transmission from the client to the server is by using
   /hostssl/ in /pg_hba.conf/. * Database user passwords are
   automatically encrypted when stored in version 7.3. In previous
   versions, you must enable the option /PASSWORD_ENCRYPTION/ in
   /postgresql.conf/. * The server can run using an encrypted file
   system.
   ----------------------------------------------------------------------
   -- Extending PostgreSQL 5.1) I wrote a user-defined function. When I
   run it in /psql/, why does it dump core? The problem could be a number
   of things. Try testing your user-defined function in a stand-alone
   test program first. 5.2) How can I contribute some nifty new types and
   functions to PostgreSQL? Send your extensions to the /pgsql-hackers/
   mailing list, and they will eventually end up in the /contrib//
   subdirectory. 5.3) How do I write a C function to return a tuple? In
   versions of PostgreSQL beginning with 7.3, table-returning functions
   are fully supported in C, PL/PgSQL, and SQL. See the Programmer's
   Guide for more information. An example of a table-returning function
   defined in C can be found in /contrib/tablefunc/. 5.4) I have changed
   a source file. Why does the recompile not see the change? The
   /Makefiles/ do not have the proper dependencies for include files. You
   have to do a /make clean/ and then another /make/. If you are using
   GCC you can use the /--enable-depend/ option of /configure/ to have
   the compiler compute the dependencies automatically.
@


1.1.2.1
log
@Add Hungarian/Turkish FAQ's to 7.3.4.
@
text
@@

