Update FAQ items to point to existing web pages rather than duplication

such information.  Remove MySQL mention.  Move server-side debug item to
developer's FAQ.  Update URLs.
This commit is contained in:
Bruce Momjian 2005-04-23 18:57:25 +00:00
parent 19d127548c
commit c34ea747a6
2 changed files with 61 additions and 202 deletions

123
doc/FAQ
View File

@ -1,7 +1,7 @@
Frequently Asked Questions (FAQ) for PostgreSQL Frequently Asked Questions (FAQ) for PostgreSQL
Last updated: Sat Apr 23 11:22:46 EDT 2005 Last updated: Sat Apr 23 14:56:41 EDT 2005
Current maintainer: Bruce Momjian (pgman@candle.pha.pa.us) Current maintainer: Bruce Momjian (pgman@candle.pha.pa.us)
@ -148,11 +148,11 @@
PostgreSQL. The platforms that had received explicit testing at the PostgreSQL. The platforms that had received explicit testing at the
time of release are listed in the installation instructions. time of release are listed in the installation instructions.
Starting with version 8.0, PostgreSQL now runs natively on Microsoft PostgreSQL also runs natively on Microsoft Windows NT-based operating
Windows NT-based operating systems like Win2000, WinXP, and Win2003. A systems like Win2000, WinXP, and Win2003. A prepackaged installer is
prepackaged installer is available at available at http://pgfoundry.org/projects/pginstaller. MSDOS-based
http://pgfoundry.org/projects/pginstaller. MSDOS-based versions of versions of Windows (Win95, Win98, WinMe) can run PostgreSQL using
Windows (Win95, Win98, WinMe) can run PostgreSQL using Cygwin. Cygwin.
There is also a Novell Netware 6 port at http://forge.novell.com, and There is also a Novell Netware 6 port at http://forge.novell.com, and
an OS/2 (eComStation) version at an OS/2 (eComStation) version at
@ -161,9 +161,8 @@
1.4) Where can I get PostgreSQL? 1.4) Where can I get PostgreSQL?
The primary anonymous ftp site for PostgreSQL is Via web browser, use http://www.postgresql.org/ftp/, and via ftp, use
ftp://ftp.PostgreSQL.org/pub/. For mirror sites, see our main web ftp://ftp.PostgreSQL.org/pub/.
site.
1.5) Where can I get support? 1.5) Where can I get support?
@ -174,10 +173,9 @@
The major IRC channel is #postgresql on Freenode (irc.freenode.net). The major IRC channel is #postgresql on Freenode (irc.freenode.net).
To connect you can use the Unix program irc -c '#postgresql' "$USER" To connect you can use the Unix program irc -c '#postgresql' "$USER"
irc.freenode.net or use any of the other popular IRC clients. A irc.freenode.net or use any other IRC clients. A Spanish one also
Spanish one also exists on the same network, (#postgresql-es), and a exists on the same network, (#postgresql-es), and a French one,
French one, (#postgresqlfr). There is also a PostgreSQL channel on (#postgresqlfr). There is also a PostgreSQL channel on EFNet.
EFNet.
A list of commercial support companies is available at A list of commercial support companies is available at
http://techdocs.postgresql.org/companies.php. http://techdocs.postgresql.org/companies.php.
@ -194,7 +192,8 @@
The latest release of PostgreSQL is version 8.0.2. The latest release of PostgreSQL is version 8.0.2.
We plan to have major releases every ten to twelve months. We plan to have a major release every year, with minor releases every
few months.
1.8) What documentation is available? 1.8) What documentation is available?
@ -223,33 +222,19 @@
1.10) How can I learn SQL? 1.10) How can I learn SQL?
The PostgreSQL book at First, consider the PostgreSQL-specific books mentioned above. Another
http://www.postgresql.org/docs/books/awbook.html teaches SQL. There is one is "Teach Yourself SQL in 21 Days, Second Edition" at
another PostgreSQL book at http://www.commandprompt.com/ppbook. There http://members.tripod.com/er4ebus/sql/index.htm
is a nice tutorial at 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. There is also a nice tutorial at
http://www.intermedia.net/support/sql/sqltut.shtm, at http://www.intermedia.net/support/sql/sqltut.shtm, at
http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM, http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM,
and at http://sqlcourse.com. and at http://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) How do I join the development team? 1.11) How do I join the development team?
First, download the latest source and read the PostgreSQL Developers See the Developer's FAQ.
FAQ and 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.12) How does PostgreSQL compare to other DBMSs? 1.12) How does PostgreSQL compare to other DBMSs?
@ -267,13 +252,8 @@
Performance Performance
PostgreSQL's performance is comparable to other commercial and PostgreSQL's performance is comparable to other commercial and
open source databases. It is faster for some things, slower for open source databases. It is faster for some things, slower for
others. In comparison to MySQL or leaner database systems, we others. Our performance is usually +/-10% compared to other
are faster for multiple users, complex queries, and a databases.
read/write query load. MySQL is faster for simple SELECT
queries done by a few users. Of course, MySQL does not have
most of the features mentioned in the Features section above.
We are built for reliability and features, and we continue to
improve performance in every release.
Reliability Reliability
We realize that a DBMS must be reliable, or it is worthless. We We realize that a DBMS must be reliable, or it is worthless. We
@ -326,15 +306,7 @@
2.3) Does PostgreSQL have a graphical user interface? 2.3) Does PostgreSQL have a graphical user interface?
Yes, there are several graphical interfaces to PostgreSQL available. Yes, see http://techdocs.postgresql.org/guides/GUITools for a detailed
These include pgAdmin III (http://www.pgadmin.org, PgAccess
http://www.pgaccess.org), RHDB Admin (http://sources.redhat.com/rhdb/
), TORA ( http://www.globecom.net/tora/, partly commercial), and
Rekall ( http://www.rekallrevealed.org/). There is also PhpPgAdmin (
http://phppgadmin.sourceforge.net/ ), a web-based interface to
PostgreSQL.
See http://techdocs.postgresql.org/guides/GUITools for a more detailed
list. list.
_________________________________________________________________ _________________________________________________________________
@ -390,43 +362,6 @@
printing of query and process statistics which can be very useful for printing of query and process statistics which can be very useful for
debugging and performance measurements. debugging and performance measurements.
The following detailed debug instructions are to be used to provide
more detailed information for server developers debugging a problem.
It is also possible to debug the server if it isn't operating
properly. 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.
The 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 using SELECT pg_backend_pid().
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.
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.5) Why do I get "Sorry, too many clients" when trying to connect? 3.5) Why do I get "Sorry, too many clients" when trying to connect?
You have reached the default limit is 100 database sessions. You need You have reached the default limit is 100 database sessions. You need
@ -438,7 +373,7 @@
PostgreSQL releases? PostgreSQL releases?
The PostgreSQL team makes only small changes between minor releases, The PostgreSQL team makes only small changes between minor releases,
so upgrading from 7.4 to 7.4.1 does not require a dump and restore. so upgrading from 7.4.0 to 7.4.1 does not require a dump and restore.
However, major releases (e.g. from 7.3 to 7.4) often change the However, major releases (e.g. from 7.3 to 7.4) often change the
internal format of system tables and data files. These changes are internal format of system tables and data files. These changes are
often complex, so we don't maintain backward compatibility for data often complex, so we don't maintain backward compatibility for data
@ -567,11 +502,11 @@
4.6) Why are my queries slow? Why don't they use my indexes? 4.6) Why are my queries slow? Why don't they use my indexes?
Indexes are not automatically used by every query. Indexes are only Indexes are not used by every query. Indexes are used only if the
used if the table is larger than a minimum size, and the query selects table is larger than a minimum size, and the query selects only a
only a small percentage of the rows in the table. This is because the small percentage of the rows in the table. This is because the random
random disk access caused by an index scan can be slower than a disk access caused by an index scan can be slower than a straight read
straight read through the table, or sequential scan. through the table, or sequential scan.
To determine if an index should be used, PostgreSQL must have To determine if an index should be used, PostgreSQL must have
statistics about the table. These statistics are collected using statistics about the table. These statistics are collected using

View File

@ -10,7 +10,7 @@
alink="#0000ff"> alink="#0000ff">
<H1>Frequently Asked Questions (FAQ) for PostgreSQL</H1> <H1>Frequently Asked Questions (FAQ) for PostgreSQL</H1>
<P>Last updated: Sat Apr 23 11:22:46 EDT 2005</P> <P>Last updated: Sat Apr 23 14:56:41 EDT 2005</P>
<P>Current maintainer: Bruce Momjian (<A href= <P>Current maintainer: Bruce Momjian (<A href=
"mailto:pgman@candle.pha.pa.us">pgman@candle.pha.pa.us</A>) "mailto:pgman@candle.pha.pa.us">pgman@candle.pha.pa.us</A>)
@ -192,10 +192,9 @@
the time of release are listed in the installation the time of release are listed in the installation
instructions.</P> instructions.</P>
<P>Starting with version 8.0, PostgreSQL now runs natively on <P>PostgreSQL also runs natively on Microsoft Windows NT-based operating
Microsoft Windows NT-based operating systems like Win2000, WinXP, systems like Win2000, WinXP, and Win2003. A prepackaged installer is
and Win2003. A prepackaged installer is available at <a href= available at <a href= "http://pgfoundry.org/projects/pginstaller">
"http://pgfoundry.org/projects/pginstaller">
http://pgfoundry.org/projects/pginstaller</a>. MSDOS-based versions http://pgfoundry.org/projects/pginstaller</a>. MSDOS-based versions
of Windows (Win95, Win98, WinMe) can run PostgreSQL using Cygwin.</P> of Windows (Win95, Win98, WinMe) can run PostgreSQL using Cygwin.</P>
@ -207,9 +206,10 @@
<H4><A name="1.4">1.4</A>) Where can I get PostgreSQL?</H4> <H4><A name="1.4">1.4</A>) Where can I get PostgreSQL?</H4>
<P>The primary anonymous ftp site for PostgreSQL is <A href= <P>Via web browser, use <a href="http://www.postgresql.org/ftp/">
"ftp://ftp.PostgreSQL.org/pub/">ftp://ftp.PostgreSQL.org/pub/</A>. http://www.postgresql.org/ftp/</a>, and via ftp, use
For mirror sites, see our main web site.</P> <A href="ftp://ftp.PostgreSQL.org/pub/">
ftp://ftp.PostgreSQL.org/pub/</A>.</P>
<H4><A name="1.5">1.5</A>) Where can I get support?</H4> <H4><A name="1.5">1.5</A>) Where can I get support?</H4>
@ -222,7 +222,7 @@
<P>The major IRC channel is <I>#postgresql</I> on Freenode <P>The major IRC channel is <I>#postgresql</I> on Freenode
(<I>irc.freenode.net</I>). To connect you can use the Unix (<I>irc.freenode.net</I>). To connect you can use the Unix
program <CODE>irc -c '#postgresql' "$USER" irc.freenode.net</CODE> program <CODE>irc -c '#postgresql' "$USER" irc.freenode.net</CODE>
or use any of the other popular IRC clients. A Spanish one also exists or use any other IRC clients. A Spanish one also exists
on the same network, (<I>#postgresql-es</I>), and a French one, on the same network, (<I>#postgresql-es</I>), and a French one,
(<I>#postgresqlfr</I>). There is also a PostgreSQL channel on EFNet.</P> (<I>#postgresqlfr</I>). There is also a PostgreSQL channel on EFNet.</P>
@ -244,7 +244,8 @@
<P>The latest release of PostgreSQL is version 8.0.2.</P> <P>The latest release of PostgreSQL is version 8.0.2.</P>
<P>We plan to have major releases every ten to twelve months.</P> <P>We plan to have a major release every year, with minor releases
every few months.</P>
<H4><A name="1.8">1.8</A>) What documentation is available?</H4> <H4><A name="1.8">1.8</A>) What documentation is available?</H4>
@ -275,18 +276,21 @@
missing features?</H4> missing features?</H4>
<P>PostgreSQL supports an extended subset of <SMALL>SQL</SMALL>-92. <P>PostgreSQL supports an extended subset of <SMALL>SQL</SMALL>-92.
See our <A href="http://developer.PostgreSQL.org/todo.php">TODO</A> See our <A href="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A>
list for known bugs, missing features, and future plans.</P> list for known bugs, missing features, and future plans.</P>
<H4><A name="1.10">1.10</A>) How can I learn <H4><A name="1.10">1.10</A>) How can I learn
<SMALL>SQL</SMALL>?</H4> <SMALL>SQL</SMALL>?</H4>
<P>The PostgreSQL book at <A href= <P>First, consider the PostgreSQL-specific books mentioned above.
"http://www.postgresql.org/docs/books/awbook.html">http://www.postgresql.org/docs/books/awbook.html</A> Another one is "Teach Yourself SQL in 21 Days, Second Edition"
teaches <SMALL>SQL</SMALL>. There is another PostgreSQL book at <A at <A href=
href= "http://members.tripod.com/er4ebus/sql/index.htm">http://members.tripod.com/er4ebus/sql/index.htm</A></P>
"http://www.commandprompt.com/ppbook/">http://www.commandprompt.com/ppbook.</A> Many of our users like <I>The Practical SQL Handbook</I>,
There is a nice tutorial at <A href= Bowman, Judith S., et al., Addison-Wesley. Others like <I>The
Complete Reference SQL</I>, Groff et al., McGraw-Hill.</P>
There is also a nice tutorial at <A href=
"http://www.intermedia.net/support/sql/sqltut.shtm">http://www.intermedia.net/support/sql/sqltut.shtm,</A> "http://www.intermedia.net/support/sql/sqltut.shtm">http://www.intermedia.net/support/sql/sqltut.shtm,</A>
at <A href= at <A href=
"http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM"> "http://ourworld.compuserve.com/homepages/graeme_birchall/HTM_COOK.HTM">
@ -294,28 +298,11 @@
and at <A href= and at <A href=
"http://sqlcourse.com/">http://sqlcourse.com.</A></P> "http://sqlcourse.com/">http://sqlcourse.com.</A></P>
<P>Another one is "Teach Yourself SQL in 21 Days, Second Edition"
at <A href=
"http://members.tripod.com/er4ebus/sql/index.htm">http://members.tripod.com/er4ebus/sql/index.htm</A></P>
<P>Many of our users like <I>The Practical SQL Handbook</I>,
Bowman, Judith S., et al., Addison-Wesley. Others like <I>The
Complete Reference SQL</I>, Groff et al., McGraw-Hill.</P>
<H4><A name="1.11">1.11</A>) How do I join the development <H4><A name="1.11">1.11</A>) How do I join the development
team?</H4> team?</H4>
<P>First, download the latest source and read the PostgreSQL <P>See the <a href="http://www.postgresql.org/docs/faqs.FAQ_DEV.html">
Developers FAQ and documentation on our web site, or in the Developer's FAQ</A>.
distribution. Second, subscribe to the <I>pgsql-hackers</I> and
<I>pgsql-patches</I> mailing lists. Third, submit high quality
patches to pgsql-patches.</P>
<P>There are about a dozen people who have commit privileges to the
PostgreSQL <SMALL>CVS</SMALL> 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.</P>
<H4><A name="1.12">1.12</A>) How does PostgreSQL compare to other <H4><A name="1.12">1.12</A>) How does PostgreSQL compare to other
<SMALL>DBMS</SMALL>s?</H4> <SMALL>DBMS</SMALL>s?</H4>
@ -339,14 +326,7 @@
<DD>PostgreSQL's performance is comparable to other commercial and <DD>PostgreSQL's performance is comparable to other commercial and
open source databases. It is faster for some things, slower for open source databases. It is faster for some things, slower for
others. In comparison to MySQL or leaner database systems, we are others. Our performance is usually +/-10% compared to other databases.
faster for multiple users, complex queries, and a read/write query
load. MySQL is faster for simple SELECT queries done by a few users.
Of course, MySQL does not have most of the features mentioned in the
<I>Features</I> section above. We are built for reliability and
features, and we continue to improve performance in every
release. <BR>
<BR>
</DD> </DD>
<DT><B>Reliability</B></DT> <DT><B>Reliability</B></DT>
@ -419,22 +399,8 @@
<H4><A name="2.3">2.3</A>) Does PostgreSQL have a graphical user <H4><A name="2.3">2.3</A>) Does PostgreSQL have a graphical user
interface?</H4> interface?</H4>
<P>Yes, there are several graphical interfaces to PostgreSQL <P>Yes, see <a href="http://techdocs.postgresql.org/guides/GUITools">
available. These include pgAdmin III (<a http://techdocs.postgresql.org/guides/GUITools</a> for a
href="http://www.pgadmin.org">http://www.pgadmin.org</a>, PgAccess
<a href="http://www.pgaccess.org"> http://www.pgaccess.org</a>),
RHDB Admin (<a
href="http://sources.redhat.com/rhdb/">http://sources.redhat.com/rhdb/
</a>), TORA (<a href="http://www.globecom.net/tora/">
http://www.globecom.net/tora/</a>, partly commercial), and Rekall (<a
href="http://www.rekallrevealed.org/">
http://www.rekallrevealed.org/</a>). There is also PhpPgAdmin (<a
href="http://phppgadmin.sourceforge.net/">
http://phppgadmin.sourceforge.net/ </a>), a web-based interface to
PostgreSQL.</P>
<P>See <a href="http://techdocs.postgresql.org/guides/GUITools">
http://techdocs.postgresql.org/guides/GUITools</a> for a more
detailed list.</P> detailed list.</P>
<HR> <HR>
@ -522,48 +488,6 @@
that enable printing of query and process statistics which can be that enable printing of query and process statistics which can be
very useful for debugging and performance measurements.</P> very useful for debugging and performance measurements.</P>
<P><B>The following detailed debug instructions are to be used to
provide more detailed information for server developers debugging a
problem.</B></P>
<P>It is also possible to debug the server if it isn't operating
properly. First, by running <I>configure</I> with the --enable-cassert
option, many <I>assert()</I>s monitor the progress of the backend
and halt the program when something unexpected occurs.</P>
<P>The <I>postmaster</I> has a <I>-d</I> option that allows even more
detailed information to be reported. The <I>-d</I> option takes a
number that specifies the debug level. Be warned that high debug
level values generate large log files.</P>
<P>If <I>postmaster</I> is not running, you can actually run the
<I>postgres</I> backend from the command line, and type your
<SMALL>SQL</SMALL> statement directly. This is recommended
<B>only</B> 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 <I>postmaster</I>, it is not
running in an identical environment and locking/backend interaction
problems may not be duplicated.</P>
<P>If <I>postmaster</I> is running, start <I>psql</I> in one
window, then find the <SMALL>PID</SMALL> of the <I>postgres</I>
process used by <I>psql</I> using <CODE>SELECT pg_backend_pid()</CODE>.
Use a debugger to attach to the <I>postgres</I> <SMALL>PID</SMALL>.
You can set breakpoints in the debugger and issue queries from
<I>psql</I>. If you are debugging <I>postgres</I> startup, you can
set PGOPTIONS="-W n", then start <I>psql</I>. This will cause startup
to delay for <I>n</I> seconds so you can attach to the process with
the debugger, set any breakpoints, and continue through the startup
sequence.</P>
<P>You can also compile with profiling to see what functions are
taking execution time. The backend profile files will be deposited
in the <I>pgsql/data/base/dbname</I> directory. The client profile
file will be put in the client's current directory. Linux requires
a compile with <I>-DLINUX_PROFILE</I> for proper profiling.</P>
<H4><A name="3.5">3.5</A>) Why do I get <I>"Sorry, too many <H4><A name="3.5">3.5</A>) Why do I get <I>"Sorry, too many
clients"</I> when trying to connect?</H4> clients"</I> when trying to connect?</H4>
@ -577,7 +501,7 @@
to upgrade between major PostgreSQL releases?</H4> to upgrade between major PostgreSQL releases?</H4>
<P>The PostgreSQL team makes only small changes between minor releases, <P>The PostgreSQL team makes only small changes between minor releases,
so upgrading from 7.4 to 7.4.1 does not require a dump and restore. so upgrading from 7.4.0 to 7.4.1 does not require a dump and restore.
However, major releases (e.g. from 7.3 to 7.4) often change the internal However, major releases (e.g. from 7.3 to 7.4) often change the internal
format of system tables and data files. These changes are often complex, format of system tables and data files. These changes are often complex,
so we don't maintain backward compatibility for data files. A dump outputs so we don't maintain backward compatibility for data files. A dump outputs
@ -727,11 +651,11 @@ table?</TD><TD>unlimited</TD></TR>
<H4><A name="4.6">4.6</A>) Why are my queries slow? Why don't they <H4><A name="4.6">4.6</A>) Why are my queries slow? Why don't they
use my indexes?</H4> use my indexes?</H4>
<P>Indexes are not automatically used by every query. Indexes are only <P>Indexes are not used by every query. Indexes are used only if the
used if the table is larger than a minimum size, and the query table is larger than a minimum size, and the query selects only a
selects only a small percentage of the rows in the table. This is small percentage of the rows in the table. This is because the random
because the random disk access caused by an index scan can be disk access caused by an index scan can be slower than a straight read
slower than a straight read through the table, or sequential scan. </P> through the table, or sequential scan. </P>
<P>To determine if an index should be used, PostgreSQL must have <P>To determine if an index should be used, PostgreSQL must have
statistics about the table. These statistics are collected using statistics about the table. These statistics are collected using