2010-04-05 04:46:42 +02:00
|
|
|
<!-- $PostgreSQL: pgsql/doc/src/sgml/release-9.0.sgml,v 2.15 2010/04/05 02:46:42 tgl Exp $ -->
|
2009-08-18 00:14:44 +02:00
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
|
|
|
|
<sect1 id="release-9-0">
|
|
|
|
<title>Release 9.0</title>
|
|
|
|
|
|
|
|
<note>
|
|
|
|
<title>Release date</title>
|
|
|
|
<simpara>2010-??-??</simpara>
|
|
|
|
</note>
|
|
|
|
|
|
|
|
<sect2>
|
|
|
|
<title>Overview</title>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
ADD HERE
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<!-- This list duplicates items below, but without authors or details-->
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The above items are explained in more detail in the sections below.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
<sect2>
|
|
|
|
|
|
|
|
<title>Migration to Version 9.0</title>
|
|
|
|
<para>CURRENT AS OF 2010-03-15</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
A dump/restore using <application>pg_dump</application> is
|
|
|
|
required for those wishing to migrate data from any previous
|
|
|
|
release.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Observe the following incompatibilities:
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Server Settings</title>
|
|
|
|
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Remove server variable <varname>add_missing_from</>, which was
|
2010-04-01 02:32:53 +02:00
|
|
|
defaulted to off for many years (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-04-05 04:46:42 +02:00
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Remove server variable <varname>regex_flavor</>, which
|
|
|
|
was defaulted to <link
|
|
|
|
linkend="posix-syntax-details"><literal>advanced</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
(e.g. Perl-regex compatible) for many years (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-04-05 04:46:42 +02:00
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
</itemizedlist>
|
2010-04-05 04:46:42 +02:00
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Queries</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
When querying a <link linkend="ddl-inherit">parent table</link>,
|
|
|
|
do not do additional permission checks on child tables
|
2010-04-01 02:32:53 +02:00
|
|
|
returned as part of the query (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The SQL standard specifies this behavior.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Have fractional seconds conversion truncate rather than
|
2010-04-01 02:32:53 +02:00
|
|
|
round when using float-based dates/times (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>String Handling</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-05 04:46:42 +02:00
|
|
|
Improve standards compliance of <link
|
|
|
|
linkend="functions-similarto-regexp"><literal>SIMILAR TO</></link>
|
|
|
|
patterns and SQL-style <function>substring()</> patterns (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-04-05 04:46:42 +02:00
|
|
|
This includes treating <literal>?</> and <literal>{...}</> as
|
|
|
|
pattern metacharacters, while they were simple literal characters
|
|
|
|
before; that corresponds to new features added in SQL:2008.
|
|
|
|
Also, <literal>^</> and <literal>$</> are now treated as simple
|
|
|
|
literal characters; formerly they were treated as metacharacters,
|
|
|
|
as if the pattern were following POSIX rather than SQL rules.
|
|
|
|
Also, in SQL-standard <function>substring()</>, use of parentheses
|
|
|
|
for nesting no longer interferes with capturing of a substring.
|
|
|
|
Also, processing of bracket expressions (character classes) is
|
|
|
|
now more standards-compliant.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-05 04:46:42 +02:00
|
|
|
Reject negative length values in 3-parameter <link
|
|
|
|
linkend="functions-string-sql"><function>substring()</></link>
|
|
|
|
for bit strings, per the SQL standard (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Object Renaming</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Tighten enforcement of column renaming when a child table inherits
|
|
|
|
the renamed column from an unrelated parent (KaiGai Kohei)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
No longer rename index names and index column names when table
|
2010-04-01 02:32:53 +02:00
|
|
|
columns are renamed (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Administrators still can rename such columns manually. Expression
|
|
|
|
index names are also not renamed. WHY ARE EXPRESSION INDEXES
|
|
|
|
SIGNIFICANT?
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>PL/pgSQL Variables</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Have PL/pgSQL throw an error if a variable name conflicts with a
|
2010-04-01 02:32:53 +02:00
|
|
|
column name used in a query (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
This behavior can be changed via the server variable <link
|
|
|
|
linkend="plpgsql-var-subst"><varname>plpgsql.variable_conflict</></link>,
|
|
|
|
or by the per-function option <literal>#variable_conflict</>.
|
|
|
|
The former behavior was to bind to variable names over
|
|
|
|
column names.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Remove PL/pgSQL's <literal>RENAME</> declaration option (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Instead, use <link
|
|
|
|
linkend="plpgsql-declaration-parameters"><literal>ALIAS</></link>,
|
|
|
|
which can now alias any variable, not just dollar sign
|
|
|
|
variables, e.g. <literal>$1</>.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
PL/pgSQL no longer allows unquoted variables names that match SQL
|
2010-04-01 02:32:53 +02:00
|
|
|
reserved words (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Variables can be double-quoted to avoid this restriction.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
<sect2>
|
|
|
|
<title>Changes</title>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Server</title>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Continuous Archiving</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow continuous archive standby systems to accept read-only queries
|
|
|
|
(Simon, Heikki)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This feature is called Hot Standby. There are new
|
2010-03-21 01:43:40 +01:00
|
|
|
<filename>postgresql.conf</> and <filename>recovery.conf</>
|
|
|
|
settings to enable this feature, as well as extensive
|
|
|
|
<link linkend="hot-standby">documentation</link>.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow continuous archive (<acronym>WAL</>) files to be streamed to a
|
2010-03-21 01:43:40 +01:00
|
|
|
standby system (Fujii Masao, Heikki)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously <acronym>WAL</> files could be sent to standby systems only
|
|
|
|
as 16 megabytes files; this allows master changes to be sent to the
|
|
|
|
slave with very little delay. There are new <filename>postgresql.conf</>
|
2010-03-21 01:43:40 +01:00
|
|
|
and <filename>recovery.conf</> settings to enable this
|
|
|
|
feature, as well as extensive <link
|
|
|
|
linkend="streaming-replication">documentation</link>.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="functions-recovery-info-table"><function>pg_last_xlog_receive_location()</></link>
|
|
|
|
and <function>pg_last_xlog_replay_location()</>, which
|
|
|
|
can be used to monitor standby server <acronym>WAL</>
|
2010-03-23 03:28:48 +01:00
|
|
|
activity (Simon, Fujii Masao, Heikki)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Performance</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Improve performance of finding inherited child tables (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow per-tablespace sequential and random page cost variables
|
2010-04-01 02:18:21 +02:00
|
|
|
(<varname>seq_page_cost</>/<varname>random_page_cost</>) via
|
2010-03-21 03:24:29 +01:00
|
|
|
<link linkend="SQL-ALTERTABLESPACE"><command>ALTER TABLESPACE
|
|
|
|
... SET/RESET</></link> (Robert Haas)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Improve performance of <link
|
|
|
|
linkend="SQL-TRUNCATE"><command>TRUNCATE</></link> when
|
2010-04-01 02:32:53 +02:00
|
|
|
used in the same transaction as table creation (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Optimizer</title>
|
|
|
|
|
|
|
|
<itemizedlist>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Allow <literal>IS NOT NULL</> restrictions to use indexes (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is particularly useful for finding
|
|
|
|
<function>MAX()</>/<function>MIN()</> values in indexes that also
|
|
|
|
contain NULLs.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Remove unnecessary <link linkend="queries-join">outer
|
|
|
|
joins</link> (Robert Haas)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Outer joins where the inner side is unique and not referenced in
|
|
|
|
the query are unnecessary and are therefore now removed.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve optimizer equivalence detection of <> <type>boolean</>
|
2010-04-01 02:32:53 +02:00
|
|
|
tests (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 03:24:29 +01:00
|
|
|
<title><link linkend="geqo">GEQO</link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Use the same random seed everytime GEQO plans a query (Andres
|
|
|
|
Freund)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
While the Genetic Query Optimizer (GEQO) still selects
|
|
|
|
random plans, it now selects the same random plans for
|
2010-03-21 23:12:27 +01:00
|
|
|
identical queries. You can modify <link
|
|
|
|
linkend="guc-geqo-seed">geqo_seed</link> to randomize
|
|
|
|
the starting value of the random plan generator.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Improve GEQO plan selection (Tom Lane).
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This avoids the rare error, "failed to make a valid plan".
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Optimizer Statistics</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Improve <link linkend="SQL-ANALYZE"><command>ANALYZE</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
to support inheritance-tree statistics (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is particularly useful for partitioned tables.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Improve <link linkend="routine-vacuuming">autovacuum</link>
|
2010-04-01 02:32:53 +02:00
|
|
|
detection of when re-analyze is necessary (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve optimizer statistics for greater/less-than comparisons
|
2010-04-01 02:32:53 +02:00
|
|
|
(Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
When looking up optimizer statistics for greater/less-than comparisons,
|
|
|
|
if the comparison value is in the first or last histogram bucket,
|
|
|
|
use an index to generate the actual statistics. This is particularly
|
|
|
|
useful for columns that are always increasing, and hence often have
|
|
|
|
inaccurate statistics.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Allow setting of distinct statistics using <link
|
|
|
|
linkend="SQL-ALTERTABLE"><command>ALTER TABLE</></link>
|
2010-03-20 04:30:12 +01:00
|
|
|
(Robert Haas)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows user-override of the number or percentage of distinct
|
|
|
|
values for a column and optionally its child tables. This value
|
|
|
|
is normally computed by <command>ANALYZE</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Authentication</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add support for <link
|
|
|
|
linkend="auth-radius"><acronym>RADIUS</></link> (Remote
|
|
|
|
Authentication Dial In User Service) authentication
|
2010-04-01 02:32:53 +02:00
|
|
|
(Magnus Hagander)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow <link linkend="auth-ldap"><acronym>LDAP</></link>
|
|
|
|
(Lightweight Directory Access Protocol) authentication
|
|
|
|
to operate in "search/bind" mode (Robert Fleming, Magnus)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows the user to be looked up first, then the system uses
|
|
|
|
the <acronym>DN</> (Distinguished Name) returned for that user.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="auth-pg-hba-conf"><literal>samehost</></link>
|
|
|
|
and <literal>samenet</> designations to
|
2010-03-20 04:30:12 +01:00
|
|
|
<filename>pg_hba.conf</> (Stef Walter)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
These match the server's <acronym>IP</> address and network address
|
|
|
|
respectively.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Monitoring</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add the ability for clients to set an <link
|
|
|
|
linkend="libpq-connect-application-name">application
|
|
|
|
name</link>, which is displayed in
|
|
|
|
<structname>pg_stat_activity</> (Dave Page)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add an SQL state option (<literal>%e</>) to <link
|
|
|
|
linkend="guc-log-line-prefix"><varname>log_line_prefix</></link>
|
2010-03-20 04:30:12 +01:00
|
|
|
(Guillaume Smet)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Write to the Windows event log in <acronym>UTF16</> encoding
|
|
|
|
(Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Statistics Counters</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="monitoring-stats-funcs-table"><function>pg_stat_reset_shared('bgwriter')</></link>
|
|
|
|
to reset the cluster-wide shared statistics of the
|
|
|
|
bgwriter (Greg Smith)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="monitoring-stats-funcs-table"><function>pg_stat_reset_single_table_counters()</></link>
|
|
|
|
and <function>pg_stat_reset_single_function_counters()</>
|
|
|
|
to allow the reseting of statistics counters for individual
|
2010-04-01 02:32:53 +02:00
|
|
|
tables and indexes (Magnus Hagander)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Server Settings</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow setting of configuration variables based on <link
|
2010-04-03 09:23:02 +02:00
|
|
|
linkend="sql-alterrole">database/role</link>
|
2010-04-01 02:32:53 +02:00
|
|
|
combinations (Alvaro Herrera)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously only per-database and per-role setting were possible,
|
|
|
|
not combinations. All role and database settings are now stored
|
|
|
|
in the new <structname>pg_db_role_setting</> system table. A new
|
|
|
|
<application>psql</> <literal>\drds</> command shows these settings.
|
|
|
|
Backwards-compatible system views do not show this information.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add boolean variable <link
|
|
|
|
linkend="guc-bonjour"><varname>bonjour</></link>, which
|
|
|
|
controls whether a Bonjour-enabled binary advertises
|
2010-04-01 02:32:53 +02:00
|
|
|
itself via <productname>Bonjour</> (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The default is off, meaning it does not advertise.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Log changed parameter values when <filename>postgresql.conf</> is
|
2010-04-01 02:32:53 +02:00
|
|
|
reloaded (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Queries</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Do <link linkend="SQL-FOR-UPDATE-SHARE"><command>SELECT
|
|
|
|
FOR UPDATE</>/<literal>SHARE</></link> processing after
|
|
|
|
applying <literal>LIMIT</>, so the number of rows returned
|
2010-04-01 02:32:53 +02:00
|
|
|
is always predictable (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously, concurrent transactions could potentially cause
|
|
|
|
<command>SELECT</> to return fewer rows than specified by
|
|
|
|
<literal>LIMIT</>. <literal>FOR UPDATE</> can still affect
|
|
|
|
<literal>ORDER BY</> ordering, but this can be corrected by using
|
|
|
|
<literal>FOR UPDATE</> in a subquery.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Allow mixing of traditional and SQL-standard <link
|
|
|
|
linkend="SQL-LIMIT"><literal>LIMIT</>/<literal>OFFSET</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
syntax in the same query (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Increase the supported frame options in <link
|
|
|
|
linkend="SQL-WINDOW">window functions</link> (Hitoshi
|
2010-03-20 04:30:12 +01:00
|
|
|
Harada)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows frames (<literal>RANGE</> or <literal>ROWS</>) to start
|
|
|
|
with <literal>CURRENT ROW</>, and to use the <literal>ROWS n
|
|
|
|
PRECEDING</>/<literal>FOLLOWING</> clause.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
2010-03-21 01:43:40 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Have <command>SELECT</> and <command>CREATE TABLE AS</> return
|
|
|
|
row counts to the client
|
|
|
|
(Boszormenyi Zoltan)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
<application>psql</> does not display these counts.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Unicode Strings</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add Unicode surrogate pair (dual 16-bit) support to
|
|
|
|
<link
|
|
|
|
linkend="sql-syntax-strings-uescape"><literal>U&</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
strings and identifiers (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow Unicode escapes in <link
|
|
|
|
linkend="sql-syntax-strings-escape"><literal>E'...'</></link>
|
|
|
|
strings (Marko Kreen)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Object Manipulation</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Speed up <link linkend="SQL-CREATEDATABASE"><command>CREATE
|
|
|
|
DATABASE</></link> by deferring flushes to disk (Andres
|
|
|
|
Freund, Greg Stark)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Allow <link linkend="SQL-COMMENT">comments</link> only on
|
|
|
|
columns of tables, views, and composite types, not other
|
2010-04-01 02:32:53 +02:00
|
|
|
objects like indexes and <acronym>TOAST</> tables (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Allow the creation of <link
|
|
|
|
linkend="SQL-CREATETYPE-enum">enumerate types</link> with
|
2010-04-01 02:32:53 +02:00
|
|
|
no labels (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is useful for supporting binary upgrades.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Have columns defined with storage type <literal>MAIN</> remain on
|
2010-03-21 03:24:29 +01:00
|
|
|
the main heap page unless it cannot fit (Kevin Grittner)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously <literal>MAIN</> values were forced to <acronym>TOAST</>
|
|
|
|
tables until the row size was one-quarter of the page size.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title><command>ALTER</></title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link linkend="SQL-ALTERDEFAULTPRIVILEGES"><command>ALTER
|
|
|
|
DEFAULT PRIVILEGES</></link> command to control privileges
|
|
|
|
of all newly-created objects (Petr Jelinek)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
It currently supports tables, views, sequences, and functions, and
|
|
|
|
also has per-schema control.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Implement <literal>IF EXISTS</> for <literal>DROP COLUMN</> and
|
|
|
|
<literal>DROP CONSTRAINT </> (Andres Freund)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <command>ALTER TABLE</> commands which rewrite tables to skip
|
|
|
|
<acronym>WAL</> logging (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Such operations either complete fully or are rolled back, so
|
|
|
|
<acronym>WAL</> archiving can be skipped, unless running in continuous
|
|
|
|
archiving mode.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="SQL-CREATETABLE"><command>CREATE TABLE</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add support for copying <literal>COMMENTS</> and <literal>STORAGE</>
|
|
|
|
to the <command>CREATE TABLE ... LIKE INCLUDING</> command (Itagaki
|
|
|
|
Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add support for copying all attributes to the <command>CREATE
|
|
|
|
TABLE LIKE INCLUDING</> command (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add the SQL-standard <command>CREATE TABLE ... OF type</> command
|
2010-04-01 02:32:53 +02:00
|
|
|
(Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows the creation of a table to match an existing composite
|
|
|
|
type. Additional constraints and defaults can be specified in the
|
|
|
|
command.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Constraints</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Add <link linkend="SQL-CREATETABLE-compatibility">deferrable
|
|
|
|
unique constraints</link> (Dean Rasheed)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows <command>UPDATE tab SET col = col + 1</> to work on
|
|
|
|
columns that have a unique indexes or are marked as primary keys,
|
|
|
|
but <literal>DEFERRABLE INITIALLY DEFERRED</> must be used to mark
|
|
|
|
the constraint as deferred.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Generalize uniqueness constraints by allowing arbitrary operator
|
|
|
|
comparisons, not just equality (Jeff Davis)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
This is enabled with the <link
|
2010-04-01 02:18:21 +02:00
|
|
|
linkend="SQL-CREATETABLE-EXCLUDE"><command>CREATE
|
2010-03-21 03:24:29 +01:00
|
|
|
TABLE CONSTRAINT ... EXCLUDE</></link> clause. While
|
|
|
|
uniqueness checks could be specified using this syntax,
|
2010-03-23 23:37:14 +01:00
|
|
|
the real value of this feature is in using complex
|
2010-03-21 03:24:29 +01:00
|
|
|
operators that do not have built-in constraints.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve the constraint violation error message to report the values
|
|
|
|
causing the failure (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
For example, a uniqueness constraint violation now reports <literal>Key
|
|
|
|
(x)=(2) already exists</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Object Permissions</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add the ability to make mass permission changes per
|
|
|
|
schema using the new <link
|
2010-03-21 03:24:29 +01:00
|
|
|
linkend="SQL-GRANT"><command>GRANT</>/<command>REVOKE
|
|
|
|
IN SCHEMA</></link> clause (Petr Jelinek)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add the ability to control large object permissions with
|
2010-03-21 03:24:29 +01:00
|
|
|
<command>GRANT</>/<command>REVOKE</>(KaiGai Kohei)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Utility Operations</title>
|
|
|
|
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Have <link linkend="SQL-LISTEN"><command>LISTEN</></link>/<link
|
|
|
|
linkend="SQL-NOTIFY"><command>NOTIFY</></link> store events
|
|
|
|
in a memory queue, rather than a system table (Joachim
|
|
|
|
Wieland)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This greatly improves performance for these operations.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow <link linkend="SQL-NOTIFY"><command>NOTIFY</></link>
|
|
|
|
to pass an optional string to listeners (Joachim Wieland)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Allow <link linkend="SQL-CLUSTER"><command>CLUSTER</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
on all system tables (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Global system tables still cannot be clustered.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="SQL-COPY"><command>COPY</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <literal>*</> as a parameter in <literal>FORCE QUOTE</> for
|
|
|
|
<literal>COPY CSV</> (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This forces quotes for all <acronym>CSV</> output columns.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add new <command>COPY</> syntax that allows parameters to be
|
|
|
|
specified in parentheses (Robert Haas, Emmanuel Cecchet)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows greater flexibility for future <command>COPY</> options.
|
|
|
|
The old syntax is still supported.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="SQL-EXPLAIN"><command>EXPLAIN</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add new <command>EXPLAIN (BUFFERS)</> to report query buffer
|
|
|
|
activity (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 23:12:27 +01:00
|
|
|
log_*_stats log output, e.g. <link
|
|
|
|
linkend="runtime-config-statistics-monitor">log_statement_stats</link>,
|
|
|
|
no longer shows this information.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add hash usage information to <command>EXPLAIN</> output (Robert
|
|
|
|
Haas)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <command>EXPLAIN</> output in <acronym>XML</>, <acronym>JSON</>,
|
|
|
|
and <acronym>YAML</> formats (Robert Haas, Greg Sabino Mullane)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <command>EXPLAIN</> options to be specified inside parentheses
|
|
|
|
(Robert Haas)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows for the expansion of <command>EXPLAIN</> options. The
|
|
|
|
old syntax is still supported.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="SQL-VACUUM"><command>VACUUM</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Change <command>VACUUM FULL</> to rewrite the entire table and
|
|
|
|
indexes, rather than moving around single rows to compact space
|
|
|
|
(Itagaki Takahiro, Tom)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The previous method was usually slower and caused index bloat.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add new <command>VACUUM</> syntax that allows parameters to be
|
|
|
|
specified in parentheses (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows greater flexibility for future <command>VACUUM</>
|
|
|
|
options. The old syntax is still supported.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Indexes</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow an index to be auto-named by not supplying an index name to
|
2010-04-01 02:32:53 +02:00
|
|
|
<link linkend="SQL-CREATEINDEX"><command>CREATE INDEX</></link> (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow <link linkend="SQL-REINDEX"><command>REINDEX</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
on system indexes (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
WAS THIS POSSIBLE ON ANY SYSTEM TABLE BEFORE? NON-HARDWIRED ONES?
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Add <literal>point_ops</> opclass for GiST (Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
DETAILS?
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Use red-black trees for <acronym>GIN</> index creation
|
|
|
|
(Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Red-black trees are self-balanced so allow for faster index
|
|
|
|
creation.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Data Types</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow hex values to be specified in <link
|
|
|
|
linkend="datatype-binary"><type>bytea</></link> strings
|
2010-04-01 02:32:53 +02:00
|
|
|
(Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 23:12:27 +01:00
|
|
|
The variable <link
|
|
|
|
linkend="guc-bytea-output">bytea_output</link> controls
|
|
|
|
if hex (default) or octal escapes are used for <type>bytea</>
|
|
|
|
output. (SWITCH DEFAULT FOR BETA? PETER) Libpq's
|
|
|
|
<function>PQescapeByteaConn()</> now uses the hex format
|
|
|
|
for <productname>PostgreSQL</> 9.0 servers.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 23:12:27 +01:00
|
|
|
Allow <link
|
|
|
|
linkend="guc-extra-float-digits">extra_float_digits</link>
|
2010-04-01 02:32:53 +02:00
|
|
|
to be increased to <literal>3</> (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The previous maximum <varname>extra_float_digits</> was <literal>2</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 03:24:29 +01:00
|
|
|
<title><link linkend="textsearch">Full Text Search</link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add prefix support for the full text search synonym dictionary
|
2010-04-01 02:32:53 +02:00
|
|
|
(Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Add full text search filtering dictionaries (Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Filtering dictionaries allow tokens to be modified and passed to
|
|
|
|
subsequent dictionaries.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Allow underscores in full text email addresses (Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Functions</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow case-insensitive <link
|
|
|
|
linkend="functions-posix-regexp">regular expression</link>
|
|
|
|
matching with <acronym>UTF-8</> server encodings.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously, only <acronym>ASCII</> characters and single-byte
|
|
|
|
encodings worked properly. Other multi-byte, non-<acronym>UTF-8</>
|
|
|
|
encodings are still broken for case-insensitive regular expression
|
|
|
|
matching.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow function calls to supply parameter names and match them to named
|
|
|
|
parameters in the function definition (Pavel Stehule)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
For example, if a function is defined to take parameters <literal>a</>
|
|
|
|
and <literal>b</>, it can be called with <literal>func(7 AS a, 12
|
|
|
|
AS b)</> or <literal>func(12 AS b, 7 AS a)</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add support for <link
|
|
|
|
linkend="functions-formatting"><function>to_char()</></link>
|
|
|
|
scientific notation output (<link
|
|
|
|
linkend="functions-formatting-numeric-table"><literal>'EEEE'</></link>)
|
|
|
|
(Pavel Stehule, Brendan Jurd)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Have <function>to_char()</> honor <link
|
|
|
|
linkend="functions-formatting-datetimemod-table"><literal>'FM'</></link>
|
|
|
|
(fill mode) in <literal>'Y'</>, <literal>'YY'</>, and
|
2010-04-01 02:32:53 +02:00
|
|
|
<literal>'YYY'</> specifications (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
It was already honored by <literal>'YYYY'</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Correct calculations of <link
|
|
|
|
linkend="functions-geometry-op-table">"overlap"</link>
|
2010-04-01 02:32:53 +02:00
|
|
|
and "contains" operations over polygons (Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Aggregates</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow aggregate functions to use <literal>ORDER BY</> (Andrew
|
|
|
|
Gierth)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
For example, this is now supported, <literal>array_agg(a ORDER BY
|
|
|
|
b)</>. This is useful for aggregates where the order of values is
|
|
|
|
significant.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add the <link
|
|
|
|
linkend="functions-aggregate-table"><function>string_agg()</></link>
|
|
|
|
aggregate function which aggregates values into a single
|
|
|
|
string (Pavel Stehule)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
An optional second argument allows specification of a delimiter.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Aggregate functions that are called with <literal>DISTINCT</> are
|
|
|
|
now passed NULL values if the aggregate transition function is
|
|
|
|
not marked as <literal>STRICT</> (Andrew Gierth)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
For example, <literal>agg(DISTINCT x)</> might pass NULL <literal>x</>
|
|
|
|
values to <function>agg()</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Bit Strings</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="functions-binarystring-other"><function>get_bit()</></link>
|
|
|
|
and <function>set_bit()</> functions for <type>bit</>
|
|
|
|
strings, mirroring those for <type>bytea</> (Leonardo
|
|
|
|
F)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Implement <link
|
|
|
|
linkend="functions-string-sql"><function>OVERLAY()</></link>
|
|
|
|
(replace) for <type>bit</> strings and <type>bytea</>
|
|
|
|
(Leonardo F)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Object Information Functions</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="functions-admin-dbsize"><function>pg_table_size()</></link>
|
|
|
|
and <function>pg_indexes_size()</> to provide a more
|
|
|
|
user-friendly interface to the <function>pg_relation_size()</>
|
|
|
|
function (Bernd Helmle)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="functions-info-access-table"><function>has_sequence_privilege()</></link>
|
|
|
|
for sequence permission checking (Abhijit Menon-Sen)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Have <link linkend="information-schema">information
|
|
|
|
schema</link> properly display date type octet lengths
|
2010-04-01 02:32:53 +02:00
|
|
|
(Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The reported length is now the maximum octet length; previously,
|
|
|
|
a huge value was reported.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Speed up information schema privilege views (Joachim Wieland)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Function and Trigger Creation</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Implement anonymous functions using the <link
|
|
|
|
linkend="SQL-DO"><command>DO</></link> statement (Petr
|
|
|
|
Jelinek, Joshua Tolley, Hannu Valtonen)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows execution of server-side code without the need to create
|
|
|
|
a new function and execute it.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow SQL-compliant <link
|
|
|
|
linkend="SQL-CREATETRIGGER">per-column triggers</link>
|
|
|
|
(Itagaki Takahiro)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Such triggers are fired only if the specified columns are affected
|
|
|
|
by the query, e.g. in <command>UPDATE</>'s <literal>SET</> list.
|
|
|
|
information_schema now also shows this information.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <literal>WHERE</> clause to <link
|
|
|
|
linkend="SQL-CREATETRIGGER"><command>CREATE TRIGGER</></link>
|
|
|
|
to allow control over whether a trigger is fired (Takahiro
|
|
|
|
Itagaki)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
While a check can be performed inside the trigger, doing it in an
|
|
|
|
external <literal>WHERE</> clause has performance benefits.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Server-Side Languages</title>
|
|
|
|
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add the <literal>OR REPLACE</> clause to <link
|
|
|
|
linkend="SQL-CREATELANGUAGE"><command>CREATE LANGUAGE</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
(Tom Lane)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is helpful to optionally install a language if it does not
|
|
|
|
already exist, and is particularly helpful now that PL/pgSQL is
|
|
|
|
installed by default.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="plpgsql">PL/PgSQL</link> Server-Side
|
|
|
|
Language</title>
|
2010-03-20 15:03:31 +01:00
|
|
|
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-05 04:46:42 +02:00
|
|
|
Install server-side language PL/pgSQL by default (Bruce Momjian)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow PL/pgSQL to handle row types with dropped columns (Pavel Stehule)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <literal>IN</> parameters to be assigned values within
|
|
|
|
PL/pgSQL functions (Steve Prentice)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Improve error location reporting in PL/pgSQL (Tom Lane)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Have PL/pgSQL use the main lexer, rather than a custom version (Tom Lane)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="plpgsql-cursors">PL/pgSQL Cursors</link></title>
|
2010-03-20 15:03:31 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add count and <literal>ALL</> options to <command>MOVE
|
|
|
|
FORWARD</>/<literal>BACKWARD</> in PL/pgSQL (Pavel Stehule)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow PL/pgSQL's <literal>WHERE CURRENT OF</> to use a cursor
|
2010-04-01 02:32:53 +02:00
|
|
|
variable (Tom Lane)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add PL/pgSQL's <command>OPEN cursor FOR EXECUTE</> to use parameters
|
|
|
|
(Pavel Stehule, Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is accomplished with a new <literal>USING</> clause.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="plperl">PL/Perl</link> Server-Side Language</title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Add new PL/Perl functions: <link
|
|
|
|
linkend="plperl-utility-functions"><function>quote_literal()</></link>,
|
2010-03-20 15:03:31 +01:00
|
|
|
<function>quote_nullable()</>, <function>quote_ident()</>,
|
|
|
|
<function>encode_bytea()</>, <function>decode_bytea()</>,
|
2010-03-21 03:24:29 +01:00
|
|
|
<function>looks_like_number()</>,
|
|
|
|
<function>encode_array_literal()</>,
|
2010-03-20 15:03:31 +01:00
|
|
|
<function>encode_array_constructor()</> (Tim Bunce)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 23:12:27 +01:00
|
|
|
Add server variable <link
|
|
|
|
linkend="guc-plperl-on-init">plperl.on_init</link> to
|
|
|
|
specify a PL/Perl Perl initialization function (Tim
|
|
|
|
Bunce)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 23:12:27 +01:00
|
|
|
<link
|
|
|
|
linkend="guc-plperl-on-plperl-init">plperl.on_plperl_init</link>
|
|
|
|
and <varname>plperl.on_plperlu_init</> are also available
|
|
|
|
for trusted/untrusted-specific initialization.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve error context support in PL/Perl (Alexey Klyukin)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Support <command>END</> blocks in PL/Perl (Tim Bunce)
|
|
|
|
</para>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<para>
|
|
|
|
<command>END</> blocks do not currently allow database access.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <command>use strict</> in PL/Perl (Tim Bunce)
|
|
|
|
</para>
|
2010-03-21 03:24:29 +01:00
|
|
|
|
|
|
|
<para>
|
2010-03-21 23:12:27 +01:00
|
|
|
This can be enabled with the server variable <link
|
|
|
|
linkend="guc-plperl-use-strict">plperl.use_strict</link>.
|
2010-03-21 03:24:29 +01:00
|
|
|
</para>
|
2010-03-20 15:03:31 +01:00
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <command>require</> in PL/Perl (Tim Bunce)
|
|
|
|
</para>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<para>
|
|
|
|
This basically tests to see if the module is loaded, and if not,
|
|
|
|
generates an error.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <command>use feature</> in PL/Perl if Perl version 5.10 or
|
|
|
|
later is used (Tim Bunce)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Verify that PL/Perl return values are valid in the server encoding
|
2010-04-01 02:32:53 +02:00
|
|
|
(Andrew Dunstan)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve PL/Perl code structure (Tim Bunce)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
PL/Perl subroutines are now given names (Tim Bunce)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is for the use of profiling and code coverage tools. DIDN'T
|
|
|
|
THEY HAVE NAMES BEFORE?
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
PL/Perl no longer allows <application>Safe</> version 2.20 because
|
|
|
|
it is unsafe (Tim Bunce)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="plpython">PL/Python</link> Server-Side Language</title>
|
2010-03-20 15:03:31 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Add Unicode support in PL/Python (Peter Eisentraut)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Strings are automatically converted from/to the server encoding as
|
|
|
|
necessary.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve <type>bytea</> support in PL/Python (Caleb Welton)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
<type>Bytea</> values passed into PL/Python now are represented as
|
|
|
|
binary, rather than the Postgres <type>bytea</> text format. Null
|
|
|
|
bytes are now also output properly from PL/Python. <type>Boolean</>
|
|
|
|
and <type>numeric</> value passing in PL/Python was also improved.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Add <link linkend="plpython-arrays">array parameter/return
|
2010-04-01 02:32:53 +02:00
|
|
|
support</link> to PL/Python (Peter Eisentraut)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Improve mapping of domains to Python base types in PL/Python (Peter Eisentraut)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Add <application>Python</> 3 support to PL/Python (Peter Eisentraut)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
The new server-side language is called <link
|
|
|
|
linkend="plpython-python23"><literal>plpython3u</></link>.
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
2010-03-20 15:03:31 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Improve error location and exception reporting in PL/Python (Peter Eisentraut)
|
2010-03-20 15:03:31 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
2010-03-20 04:30:12 +01:00
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Client Applications</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
2010-03-20 15:03:31 +01:00
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link linkend="APP-VACUUMDB"><command>vacuumdb</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
<option>--analyze-only</> option to only analyze (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="APP-PSQL"><application>psql</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Properly escape <application>psql</> <link
|
|
|
|
linkend="APP-PSQL-variables">variables</link> and
|
|
|
|
identifiers (Pavel Stehule, Robert Haas)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
For example, <literal>:'var'</> will be escaped as a literal string, and
|
|
|
|
<literal>:"var"</> will be escaped as an SQL identifier.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Ignore leading UTF-8-encoded Unicode byte-order marker in
|
|
|
|
<application>psql</> (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is enabled when the client encoding is <acronym>UTF-8</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Fix <command>psql --file -</> to properly honor <link
|
|
|
|
linkend="R1-APP-PSQL-3"><option>--single-transaction</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
(Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Prevent overwriting of <application>psql</>'s command-line history
|
2010-04-01 02:32:53 +02:00
|
|
|
if two <application>psql</> sessions are run simultaneously (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve <application>psql</>'s tab completion support (Itagaki
|
|
|
|
Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect5>
|
|
|
|
<title><application>psql</> Display</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <application>psql</> to use fancy Unicode line-drawing
|
|
|
|
characters via <command>\pset linestyle unicode</> (Roger Leigh)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve display of wrapped columns in <application>psql</> (Roger
|
|
|
|
Leigh)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The previous format is available by using <command>\pset linestyle
|
|
|
|
old-ascii</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect5>
|
|
|
|
|
|
|
|
<sect5>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><application>psql</> <link
|
|
|
|
linkend="APP-PSQL-meta-commands"><command>\d</></link>
|
|
|
|
Commands</title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Have <command>\d</> show child tables that inherit from the specified
|
|
|
|
parent (Damien Clochard)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
<command>\d</> shows only the number of child tables, while
|
|
|
|
<command>\d+</> shows the names of all child tables.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Show definition of indexes in <command>\d index_name</> (Khee Chin)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The definition is useful for expression indexes.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
In <application>psql</>, show the view definition only with <command>\d+</>,
|
2010-04-01 02:32:53 +02:00
|
|
|
not with <command>\d</> (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect5>
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="APP-PGDUMP"><application>pg_dump</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Have <application>pg_dump</>/<application>pg_restore</>
|
|
|
|
<link linkend="pg-dump-options"><option>--clean</></link>
|
2010-03-20 04:30:12 +01:00
|
|
|
also remove large objects (Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Fix <application>pg_dump</> to properly dump large objects if
|
2010-04-01 02:32:53 +02:00
|
|
|
standard_conforming_strings is enabled (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Large objects dumps now use hex format for output. (SWITCH DEFAULT
|
|
|
|
FOR BETA? TOM)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <application>pg_dump</> to dump comments attached to columns
|
|
|
|
of composite types (Taro Minowa (Higepon))
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Have <application>pg_dump</> <link
|
|
|
|
linkend="pg-dump-options"><option>--verbose</></link>
|
|
|
|
output the <application>pg_dump</> and server versions
|
|
|
|
in text output mode (Jim Cox, Tom)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
These were already present in custom output mode.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link
|
|
|
|
linkend="app-pg-ctl"><application>pg_ctl</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <application>pg_ctl</> to be safely used to start the
|
2010-04-01 02:32:53 +02:00
|
|
|
<application>postmaster</> at boot-time (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously the <application>pg_ctl</> process could have been mistakenly
|
|
|
|
identified as a running <application>postmaster</> based on a stale
|
|
|
|
<application>postmaster</> lock file.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Give <application>pg_ctl</> the ability to initialize the database
|
|
|
|
(like <application>initdb</>) (Zdenek Kotala)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
2010-03-20 17:31:09 +01:00
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title><application>Development Tools</></title>
|
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="libpq"><application>libpq</></link></title>
|
2010-03-20 17:31:09 +01:00
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add new <application>libpq</> functions
|
2010-03-21 01:43:40 +01:00
|
|
|
<link
|
|
|
|
linkend="libpq-connect"><function>PQconnectdbParams()</></link>
|
|
|
|
and <function>PQconnectStartParams()</> (Guillaume
|
|
|
|
Lelarge)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
These functions are similar to <function>PQconnectdb()</> and
|
|
|
|
<function>PQconnectStart()</> except they allow a null-terminated
|
|
|
|
array of connection options, rather than requiring all options to
|
|
|
|
be sent in a single string.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <application>libpq</> functions <link
|
|
|
|
linkend="libpq-exec-escape-string"><function>PQescapeLiteral()</></link>
|
|
|
|
and <function>PQescapeIdentifier()</> (Robert Haas)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
These functions return appropriately quoted and escaped literal
|
|
|
|
strings and identifiers. The caller is not required to pre-allocate
|
|
|
|
the string result, as is required by <function>PQescapeStringConn()</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add checking for a per-user service file (<link
|
|
|
|
linkend="libpq-pgservice"><filename>.pg_service.conf</></link>),
|
|
|
|
which is checked before the site-wide service file
|
2010-04-01 02:32:53 +02:00
|
|
|
(Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The file <filename>.pg_service.conf</> is assumed to be in the
|
|
|
|
user's home directory.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Properly report an error if the specified <application>libpq</> service
|
2010-04-01 02:32:53 +02:00
|
|
|
cannot be found (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Issue a warning if the <link
|
|
|
|
linkend="libpq-pgpass"><filename>.pgpass</></link>-retrieved
|
2010-04-01 02:32:53 +02:00
|
|
|
password fails (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
2010-03-21 01:43:40 +01:00
|
|
|
<title><link linkend="ecpg"><application>ecpg</></link></title>
|
2010-03-20 04:30:12 +01:00
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link linkend="ecpg-descriptors"><acronym>SQLDA</></link>
|
|
|
|
(SQL Descriptor Area) support to <application>ecpg</>
|
2010-03-20 04:30:12 +01:00
|
|
|
(Boszormenyi Zoltan)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add the <link linkend="ecpg-descriptors"><command>DESCRIBE</>
|
|
|
|
[<literal>OUTPUT</>]</link> statement to <application>ecpg</>
|
|
|
|
(Boszormenyi Zoltan)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add an <application>ecpg</> <link
|
|
|
|
linkend="ecpg-library">function</link> to return the
|
|
|
|
current transaction status (Bernd Helmle)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add the <literal>string</> data type in <application>ecpg</>
|
|
|
|
Informix-compatibility mode (Zoltan Boszormenyi)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <application>ecpg</> to use <literal>new</> and <literal>old</>
|
2010-04-01 02:32:53 +02:00
|
|
|
variable names without restriction (Michael Meskes)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Have <application>ecpg</> return zero for non-SQL3 data types
|
|
|
|
(Michael Meskes))
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Previously it returned the negative of the data type <type>oid</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect5>
|
|
|
|
<title><application>ecpg</> Cursors</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add <application>ecpg</> out-of-scope cursor support in native mode
|
|
|
|
(Boszormenyi Zoltan)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows <command>DECLARE</> to use variables that are not in
|
|
|
|
scope when <command>OPEN</> is called. This facility already existed
|
|
|
|
in <application>ecpg</> Informix-compatibility mode.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow dynamic <application>ecpg</> cursor names (Boszormenyi Zoltan)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow <application>ecpg</> to use noise words <literal>FROM</> and
|
|
|
|
<literal>IN</> in <command>FETCH</> and <command>MOVE</> (Zoltan
|
|
|
|
Boszormenyi)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect5>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Build Options</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Enable client thread safety by default (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Thread-safe builds can be disabled with <link
|
|
|
|
linkend="configure"><application>configure</></link>
|
2010-03-20 04:30:12 +01:00
|
|
|
<option>--disable-thread-safety</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add a compile-time option to allow the Linux out-of-memory killer
|
|
|
|
to kill backends (Alex Hunsaker, Tom)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Now that <filename>/proc/self/oom_adj</> allows disabling
|
|
|
|
of the <productname>Linux</> out-of-memory (<acronym>OOM</>)
|
|
|
|
killer for the postmaster and its children, the new
|
|
|
|
compile-time option <link
|
|
|
|
linkend="linux-memory-overcommit"><literal>-DLINUX_OOM_ADJ=0</></link>
|
|
|
|
allows the killer to be enabled for <application>postmaster</>
|
|
|
|
children. <application>pg_config</> shows if this flag
|
|
|
|
was used during compilation.
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Use <productname>DocBook</> <acronym>XSL</> stylesheets for man page
|
2010-04-01 02:32:53 +02:00
|
|
|
building (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Makefiles</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
New <filename>Makefile</> targets <link
|
|
|
|
linkend="build"><literal>world</></link>,
|
|
|
|
<literal>install-world</>, and <literal>installcheck-world</>
|
2010-04-01 02:32:53 +02:00
|
|
|
(Andrew Dunstan)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
These are similar to the existing <literal>all</>, <literal>install</>,
|
|
|
|
and <literal>installcheck</> targets, but they build <acronym>HTML</>
|
|
|
|
documentation, build and test <filename>/contrib</>, and test
|
|
|
|
server-side languages and <application>ecpg</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add data and documentation location control to <link
|
|
|
|
linkend="xfunc-c-pgxs"><acronym>PGXS</></link> Makefiles
|
|
|
|
(Mark Cave-Ayland)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Restructure the <acronym>HTML</> documentation build
|
2010-04-01 02:32:53 +02:00
|
|
|
<filename>Makefile</> rules (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>New Requirements</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Require <application>Autoconf</> 2.63 for building from source (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Require <application>Flex</> 2.5.31 or later to build from source
|
2010-04-01 02:32:53 +02:00
|
|
|
(Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Require <application>Perl</> version 5.8 or greater to build the server
|
|
|
|
from a <acronym>CVS</> copy (John Naylor, Andrew)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Windows</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add support for compiling on <link
|
|
|
|
linkend="install-win32-full">64-bit
|
|
|
|
<productname>Windows</></link> and running in 64-bit
|
|
|
|
mode (Tsutomu Yamada, Magnus)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows for large shared memory sizes on <productname>Windows</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Allow server builds using <link
|
|
|
|
linkend="install-win32-full"><productname>Visual Studio
|
2010-04-01 02:32:53 +02:00
|
|
|
2008</></link> (Magnus Hagander)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow multi-processor compilation using <productname>Microsoft Visual
|
2010-04-01 02:32:53 +02:00
|
|
|
C</> (Magnus Hagander)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Source Code</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Distribute documentation in a proper directory tree, rather than
|
2010-04-01 02:32:53 +02:00
|
|
|
as tar archive files inside the main distribution tarball (Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
For example, the <acronym>HTML</> documentation is now in
|
|
|
|
<filename>doc/src/sgml/html</>; the manual pages are packaged
|
|
|
|
similarly.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Enable the server lexer to be reentrant (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This was needed for use of the lexer by PL/pgSQL.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve speed of memory allocation (Tom, Greg Stark)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add system columns to better document the use of indexes for constraint
|
2010-04-01 02:32:53 +02:00
|
|
|
enforcement (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow multiple actions to be communicated using the same operating
|
|
|
|
system signal (Fujii Masao)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows improved backend communication as new features are
|
|
|
|
added.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve source code test coverage, including /contrib, PL/Python,
|
|
|
|
and PL/Perl (Peter, Andrew)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Remove the use of flat files for system table bootstrapping (Tom,
|
|
|
|
Alvaro)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This also improves performance when using millions of users and
|
|
|
|
databases.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve the ability to translate <application>psql</> strings
|
2010-04-01 02:32:53 +02:00
|
|
|
(Peter Eisentraut)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Reduce the length of some file names so file paths are less than
|
2010-04-01 02:32:53 +02:00
|
|
|
100 characters (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Some decompression programs have problems with long file names.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Tighten input requirements for <type>int2</> vector input (Caleb
|
|
|
|
Welton)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
2010-03-21 01:43:40 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Add a new <link
|
|
|
|
linkend="errcodes-table"><literal>ERRCODE_INVALID_PASSWORD</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
<literal>SQLSTATE</> error code (Bruce Momjian)
|
2010-03-21 01:43:40 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
2010-03-20 04:30:12 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Properly remove the few remaining personal source code copyright
|
2010-04-01 02:32:53 +02:00
|
|
|
entries (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The personal copyright notices were insignificant but the community
|
|
|
|
occasionally had to answer questions about them.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Feature Support</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-04-01 02:32:53 +02:00
|
|
|
Use a more modern <acronym>API</> for <application>Bonjour</> (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Bonjour now requires <productname>OS X</> 10.3 or later.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add processor test-and-test lock support for the <productname>SuperH</>
|
|
|
|
architecture (Nobuhiro Iwamatsu)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow non-<application>GCC</> compilers to use inline functions if
|
|
|
|
they support them (Kurt Harriman)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Remove support for platforms that don't have a working 64-bit
|
2010-04-01 02:32:53 +02:00
|
|
|
integer data types (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
It is believed all supported platforms have working 64-bit integer
|
|
|
|
data types.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Server Programming</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow use of <productname>C++</> functions in backend code (Kurt
|
|
|
|
Harriman, Peter)
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This removes keyword conflicts that previously made <productname>C++</>
|
|
|
|
usage difficult in backend code. <literal>extern "C" { }</> might still
|
|
|
|
be necessary.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="xaggr"><function>AggCheckCallContext()</></link>
|
|
|
|
for use in detecting if a <productname>C</> function is
|
|
|
|
being called as an aggregate (Hitoshi Harada)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Require <function>fastgetattr()</> and <function>heap_getattr()</>
|
|
|
|
backend macros to use a non-NULL fourth argument (Robert Haas)
|
|
|
|
KEEP?
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Server Hooks</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add parser hooks to access column and parameter references in
|
2010-04-01 02:32:53 +02:00
|
|
|
queries (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add a hook so loadable modules can control utility commands (Itagaki
|
|
|
|
Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow the calling of parser hooks from <acronym>SPI</> and cached
|
2010-04-01 02:32:53 +02:00
|
|
|
plans (Tom Lane)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>Binary Upgrade Support</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add support for preservation of all <link
|
|
|
|
linkend="catalog-pg-class"><structname>relfilenodes</></link>,
|
2010-04-01 02:32:53 +02:00
|
|
|
for use during binary upgrades (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add support for binary upgrades to preserve <structname>pg_type</>
|
2010-04-01 02:32:53 +02:00
|
|
|
and <structname>pg_enum</> <type>oids</> (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This is needed to allow binary upgrades of user-defined composite
|
|
|
|
types, arrays, and enums (enumerated types).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Move tablespace data directories into their own
|
2010-04-01 02:32:53 +02:00
|
|
|
<productname>PostgreSQL</> version-specific subdirectory (Bruce Momjian)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This simplifies binary upgrades.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
|
|
|
|
<sect3>
|
|
|
|
<title>Contrib</title>
|
|
|
|
<itemizedlist>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add multi-threaded option (<option>-j</>) to <link
|
|
|
|
linkend="pgbench"><filename>/contrib/pgbench</></link>
|
|
|
|
(Itagaki Takahiro)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows multiple <acronym>CPU</>s to be used for pgbench tests.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 03:24:29 +01:00
|
|
|
Add <command>\shell</> and <command>\setshell</> meta
|
|
|
|
commands to <link
|
|
|
|
linkend="pgbench"><filename>/contrib/pgbench</></link>
|
|
|
|
(Michael Paquier)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
New features for <link
|
|
|
|
linkend="dict-xsyn"><filename>/contrib/dict_xsyn</></link>
|
|
|
|
(Sergey Karpov)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The new options are <literal>matchorig</>, <literal>matchsynonyms</>,
|
|
|
|
and <literal>keepsynonyms</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add full text dictionary <link
|
|
|
|
linkend="unaccent"><filename>/contrib/unaccent</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
(Teodor Sigaev)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This filter dictionary removes accents from tokens.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="CONTRIB-DBLINK-GET-NOTIFY"><function>dblink_get_notify()</></link>
|
|
|
|
to <filename>/contrib/dblink</> (Marcus Kempe)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This allows async notifications in <productname>dblink</>.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Greatly increase <link
|
|
|
|
linkend="hstore"><filename>/contrib/hstore</></link>'s
|
|
|
|
length limit and add btree and hash abilities so <literal>GROUP
|
|
|
|
BY</> and <literal>DISTINCT</> operations are possible
|
|
|
|
(Andrew Gierth)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
New functions and operators were also added.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add <link
|
|
|
|
linkend="passwordcheck"><filename>/contrib/passwordcheck</></link>
|
|
|
|
which can check the strength of assigned passwords (Laurenz
|
|
|
|
Albe)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
The source code of this module should be modified to implement
|
|
|
|
site-specific password policies.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add query text to <link
|
|
|
|
linkend="auto-explain"><filename>/contrib/auto_explain</></link>
|
2010-04-01 02:32:53 +02:00
|
|
|
output (Andrew Dunstan)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Add buffer access counters to <link
|
|
|
|
linkend="pgstatstatements"><filename>/contrib/pg_stat_statements</></link>
|
2010-03-20 04:30:12 +01:00
|
|
|
(Itagaki Takahiro)
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-03-21 01:43:40 +01:00
|
|
|
Update <link
|
|
|
|
linkend="server-start"><filename>/contrib/start-scripts/linux</></link>
|
|
|
|
to use <filename>/proc/self/oom_adj</> to disable the
|
|
|
|
<link linkend="linux-memory-overcommit"><productname>Linux</>
|
|
|
|
out-of-memory</link> (<acronym>OOM</>) killer (Alex
|
|
|
|
Hunsaker, Tom)
|
2010-03-20 04:30:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
|
|
|
|
</itemizedlist>
|
|
|
|
|
|
|
|
</sect3>
|
|
|
|
</sect2>
|
|
|
|
</sect1>
|
|
|
|
|
|
|
|
|
|
|
|
<sect1 id="release-9-0-alpha">
|
2010-02-19 01:35:18 +01:00
|
|
|
<title>Release 9.0alpha4</title>
|
2009-08-18 00:14:44 +02:00
|
|
|
<sect2>
|
|
|
|
<title>Overview</title>
|
|
|
|
<para>
|
|
|
|
PostgreSQL alpha releases are snapshots of development code. They
|
|
|
|
are intended to preview and test upcoming features and to provide
|
|
|
|
the possibility for early feedback. They should not be used in
|
|
|
|
production installations or active development projects. While the
|
|
|
|
PostgreSQL code is continuously subject to a number of automated
|
|
|
|
and manual tests, alpha releases might have serious bugs. Also
|
|
|
|
features may be changed incompatibly or removed at any time during
|
|
|
|
the development cycle.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The development cycle of a PostgreSQL major release alternates
|
|
|
|
between periods of development and periods of integration work,
|
|
|
|
called commit fests, normally one month each. Alpha releases are
|
|
|
|
planned to be produced at the end of every commit fest, thus every
|
|
|
|
two months. Since the first commit fest starts within a month from
|
|
|
|
the beginning of development altogether, early alpha releases are
|
|
|
|
not indicative of the likely feature set of the final release.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The release notes below highlight user visible changes and new
|
|
|
|
features. There are normally numerous bug fixes and performance
|
|
|
|
improvements in every new snapshot of PostgreSQL, and it would be
|
|
|
|
too bulky to attempt to list them all. Note that many bug fixes are
|
|
|
|
also backported to stable releases of PostgreSQL, and you should be
|
|
|
|
using those if you are looking for bug-fix-only upgrades for your
|
|
|
|
current installations.
|
|
|
|
</para>
|
2009-10-20 21:52:58 +02:00
|
|
|
<para>
|
|
|
|
The release notes are cumulative over all alpha releases. Items
|
|
|
|
that are new in the latest alpha release
|
|
|
|
are <emphasis>emphasized</emphasis>.
|
|
|
|
</para>
|
2009-08-18 00:14:44 +02:00
|
|
|
</sect2>
|
|
|
|
<sect2>
|
|
|
|
<title>Migration</title>
|
|
|
|
<para>
|
|
|
|
To upgrade from any release to an alpha release or from an alpha
|
|
|
|
release to any other release will most likely require a
|
|
|
|
dump/restore upgrade procedure. It may happen that this is not
|
|
|
|
necessary in particular cases, but that is not verified beforehand.
|
|
|
|
(The server will warn you in any case when a dump/restore is
|
|
|
|
necessary if you attempt to use it with an old data directory.)
|
|
|
|
Note, however, that the dump/restore upgrade procedure is expected
|
|
|
|
to work for alpha releases, and problems in this area should be
|
|
|
|
reported.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
2009-10-21 21:43:06 +02:00
|
|
|
<sect2>
|
|
|
|
<title>Testing</title>
|
|
|
|
<para>
|
2009-12-19 03:38:54 +01:00
|
|
|
The primary reason we release alphas is to get users to test new
|
2009-10-21 21:43:06 +02:00
|
|
|
features as early as possible. If you are interested in helping
|
2009-12-19 03:38:54 +01:00
|
|
|
with organized testing, please see
|
|
|
|
<ulink url="http://wiki.postgresql.org/wiki/HowToBetaTest">the
|
2009-10-21 21:43:06 +02:00
|
|
|
testing information page</ulink>.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
2009-08-18 00:14:44 +02:00
|
|
|
<sect2>
|
|
|
|
<title>Changes</title>
|
|
|
|
<sect3>
|
|
|
|
<title>SQL Features</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Disallow comments on columns of relation types
|
|
|
|
other than tables, views, and composite types, that is,
|
|
|
|
sequences and TOAST tables.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Adjust naming of indexes and their columns. Index
|
|
|
|
expression columns are now named after the FigureColname
|
|
|
|
result for their expressions, rather than always being
|
|
|
|
"pg_expression_N". Digits are appended to this name if
|
|
|
|
needed to make the column name unique within the index.
|
|
|
|
Default names for indexes and associated constraints now
|
|
|
|
include the column names of all their columns, not only the
|
|
|
|
first one as in previous practice.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Allow the index name to be omitted in CREATE INDEX,
|
|
|
|
causing the system to choose an index name the same as it
|
|
|
|
would do for an unnamed index constraint. A necessary
|
|
|
|
side-effect is to promote the word CONCURRENTLY to a more
|
|
|
|
reserved status; it can't be a table/column/index name
|
|
|
|
anymore unless quoted.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Improve the handling of SET CONSTRAINTS commands by
|
|
|
|
having them search pg_constraint before searching pg_trigger.
|
|
|
|
This allows saner handling of corner cases.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Typed table feature; this adds the CREATE TABLE
|
|
|
|
name OF type command.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Tighten integrity checks on ALTER TABLE ... RENAME
|
|
|
|
COLUMN in inheritance hierarchies.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Replace the pg_listener-based LISTEN/NOTIFY
|
|
|
|
mechanism with an in-memory queue. In addition, add support
|
|
|
|
for a "payload" string to be passed along with each notify
|
|
|
|
event.</emphasis>
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
<emphasis>This implementation should be significantly more
|
|
|
|
efficient than the old one, and is also more compatible with
|
|
|
|
Hot Standby usage. There is not yet any facility for HS
|
|
|
|
slaves to receive notifications generated on the master,
|
|
|
|
although such a thing is possible in future.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Have SELECT and CREATE TABLE AS queries return a
|
|
|
|
row count. While this is invisible in psql, other
|
|
|
|
interfaces, like libpq, make this value visible.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Extend the set of frame options supported for
|
|
|
|
window functions. This allows the frame to start from
|
|
|
|
CURRENT ROW (in either RANGE or ROWS mode), and it also adds
|
|
|
|
support for ROWS n PRECEDING and ROWS n FOLLOWING start and
|
|
|
|
end points.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add DO statement to support execution of procedural language
|
|
|
|
code without having to create a function for it.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Support use of function argument names to identify which
|
|
|
|
actual arguments match which function parameters. The syntax
|
|
|
|
uses AS, for example funcname(value AS arg1, anothervalue AS
|
|
|
|
arg2).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Remove previously deprecated configuration
|
2009-12-18 23:11:09 +01:00
|
|
|
parameter add_missing_from. The system now always behaves as
|
2010-02-19 01:35:18 +01:00
|
|
|
though add_missing_from were off.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Performance and behavioral improvements in UPDATE,
|
2009-12-19 03:38:54 +01:00
|
|
|
DELETE, and SELECT FOR UPDATE/SHARE queries with joins.
|
|
|
|
Fix various corner cases that could have resulted in duplicated output
|
2009-12-18 23:11:09 +01:00
|
|
|
rows. Set-returning functions are now prohibited in the
|
|
|
|
target list of SELECT FOR UPDATE/SHARE. FOR UPDATE does not
|
2010-02-19 01:35:18 +01:00
|
|
|
propagate into a WITH query anymore.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Fix SELECT FOR UPDATE/SHARE in conjunction with LIMIT.
|
|
|
|
Previously, it could return fewer rows than the limit specified.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add a WHEN clause to CREATE TRIGGER, allowing a boolean expression
|
|
|
|
to be checked to determine whether the trigger should be fired.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
For BEFORE triggers this is mostly a matter of spec compliance; but
|
2009-12-18 23:11:09 +01:00
|
|
|
for AFTER triggers it can provide a noticeable performance
|
|
|
|
improvement, since queuing of a deferred trigger event and
|
|
|
|
re-fetching of the row(s) at end of statement can be
|
2010-02-19 01:35:18 +01:00
|
|
|
short-circuited if the trigger does not need to be fired.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add exclusion constraints, which generalize the concept of
|
2009-12-18 23:11:09 +01:00
|
|
|
uniqueness to support any indexable commutative operator, not just
|
|
|
|
equality. Two rows violate the exclusion constraint if
|
|
|
|
"row1.col OP row2.col" is TRUE for each of the columns in
|
2010-02-19 01:35:18 +01:00
|
|
|
the constraint.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Support ORDER BY within aggregate function calls, at long last
|
2009-12-18 23:11:09 +01:00
|
|
|
providing a non-kluge method for controlling the order in which
|
|
|
|
values are fed to an aggregate function. At the same time eliminate
|
|
|
|
the old implementation restriction that DISTINCT was only supported
|
2010-02-19 01:35:18 +01:00
|
|
|
for single-argument aggregates.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Behavioral change: formerly, agg(DISTINCT x) dropped null values of
|
2009-12-19 03:38:54 +01:00
|
|
|
x unconditionally. Now, it does so only if the aggregate's transition
|
2009-12-18 23:11:09 +01:00
|
|
|
function is strict; otherwise nulls are treated as DISTINCT
|
2010-02-19 01:35:18 +01:00
|
|
|
normally would, i.e., you get one copy.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add SQL-compliant triggers on columns, which fire only if
|
|
|
|
certain columns are named in the UPDATE's SET list.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add CREATE LIKE INCLUDING COMMENTS and STORAGE, and INCLUDING
|
2009-10-21 21:43:06 +02:00
|
|
|
ALL shortcut to allow users to make an exact copy of a table including
|
2009-12-18 23:11:09 +01:00
|
|
|
all options and features.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Define a new, more extensible syntax for COPY options
|
|
|
|
in order to support additional COPY options in the future.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Modify the definition of window-function PARTITION
|
2009-10-21 21:43:06 +02:00
|
|
|
BY and ORDER BY clauses so that their elements are always
|
|
|
|
taken as simple expressions over the query's input
|
2009-12-18 23:11:09 +01:00
|
|
|
columns. This fixes a bug.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Fix bug with nested WITH RECURSIVE statements.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Add surrogate pair support for U& string and identifier
|
|
|
|
syntax.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Add Unicode escapes in E'...' strings.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
DROP COLUMN and DROP CONSTRAINT now support an IF EXISTS clause so
|
|
|
|
that users can avoid fatal errors when running repeatable scripts.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
UNIQUE constraints can now be DEFERRABLE. This is primarily useful
|
|
|
|
for incremental updates of numerical keys, e.g. "ID = ID +
|
|
|
|
1"
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-10-20 21:52:58 +02:00
|
|
|
Allow parentheses around the query expression that follows a WITH
|
2009-08-18 00:14:44 +02:00
|
|
|
clause.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
INFORMATION_SCHEMA, a catalog of standard views of database
|
2009-10-20 21:52:58 +02:00
|
|
|
objects, has been updated to the SQL:2008 standard.
|
2009-08-18 00:14:44 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-10-20 21:52:58 +02:00
|
|
|
Change character_octet_length to more sensible values in
|
2009-08-18 00:14:44 +02:00
|
|
|
INFORMATION_SCHEMA.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow * as parameter for FORCE QUOTE for COPY CSV, so that all
|
|
|
|
columns will be quoted.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
|
|
|
<title>Performance</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Support "x IS NOT NULL" clauses as index-scan
|
|
|
|
conditions.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>When estimating the selectivity of an inequality
|
|
|
|
"column > constant" or "column < constant", and the
|
|
|
|
comparison value is in the first or last histogram bin or
|
|
|
|
outside the histogram entirely, try to fetch the actual
|
|
|
|
column min or max value using an index scan (if there is an
|
|
|
|
index on the column). If successful, replace the lower or
|
|
|
|
upper histogram bound with that value before carrying on with
|
|
|
|
the estimate. This limits the estimation error caused by
|
|
|
|
moving min/max values when the comparison value is close to
|
|
|
|
the min or max.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Generic implementation of red-black binary tree.
|
|
|
|
For now, only GIN uses it during index creation. Using
|
|
|
|
self-balanced tree greatly speeds up index creation in corner
|
|
|
|
cases with preordered data.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow rewriting forms of ALTER TABLE to skip WAL
|
|
|
|
logging.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Speed up INFORMATION_SCHEMA's privilege views.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Make TRUNCATE do truncate-in-place when processing
|
2009-10-20 21:52:58 +02:00
|
|
|
a relation that was created or previously truncated in the
|
2009-12-18 23:11:09 +01:00
|
|
|
current (sub)transaction.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Implement "join removal" for cases where the inner side
|
2009-10-21 21:43:06 +02:00
|
|
|
of a left join is unique and is not referenced above the join. This should
|
2009-12-18 23:11:09 +01:00
|
|
|
speed up many ORM-generated and reporting tool queries.
|
2009-10-21 21:43:06 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Remove the use of the flat files pg_auth and
|
2009-10-21 21:43:06 +02:00
|
|
|
pg_database in order to improve performance. (Warning: pgbouncer
|
|
|
|
and possibly other tools currently suggest referring to the pg_auth
|
2009-12-18 23:11:09 +01:00
|
|
|
file for its user database. Such schemes will no longer work.)
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-11 02:33:35 +01:00
|
|
|
EXPLAIN allows output of plans in XML, JSON, or YAML format for automated
|
2009-08-18 00:14:44 +02:00
|
|
|
processing of explain plans by analysis or visualization tools.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
EXPLAIN now supports the use of generic options in EXPLAIN ( option
|
|
|
|
value, ... ) format, which permits the creation of additional
|
|
|
|
EXPLAIN options.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
ALTER TABLE ... ALTER COLUMN ... SET STATISTICS DISTINCT allows
|
|
|
|
users to manually tweak the number of distinct values estimated for
|
|
|
|
a column, to fix cases where ANALYZE estimates are incorrect.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-10-20 21:52:58 +02:00
|
|
|
Make GEQO's planning deterministic by having it start from a
|
2009-08-18 00:14:44 +02:00
|
|
|
predictable random number seed each time.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Rewrite GEQO's gimme_tree function so that it always finds a legal
|
|
|
|
join sequence. Previously, it could have failed to produce a plan
|
|
|
|
in some cases.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Tweak TOAST code so that columns marked with MAIN storage strategy
|
|
|
|
are not forced out-of-line unless that is necessary to make the row
|
|
|
|
fit on a page. Previously, they were forced out-of-line if needed
|
|
|
|
to get the row down to the default target size (1/4th page).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Simplify the forms foo <> true and foo <> false to foo
|
|
|
|
= false and foo = true during query optimization.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Avoid per-send() system calls to manage SIGPIPE in libpq, if the
|
|
|
|
platform provides either sockopt(SO_NOSIGPIPE) or the MSG_NOSIGNAL
|
|
|
|
flag to send().
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
|
|
|
<title>Administration and Monitoring</title>
|
|
|
|
<itemizedlist>
|
2009-12-19 21:33:12 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add the ability to store inheritance-tree
|
|
|
|
statistics in pg_statistic, and teach ANALYZE to compute such
|
|
|
|
stats for tables that have subclasses.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Revise pgstat's tracking of tuple changes to
|
|
|
|
improve the reliability of decisions about when to
|
|
|
|
auto-analyze. The previous code depended on n_live_tuples +
|
|
|
|
n_dead_tuples - last_anl_tuples, where all three of these
|
|
|
|
numbers could be bad estimates from ANALYZE itself. Even
|
|
|
|
worse, in the presence of a steady flow of HOT updates and
|
|
|
|
matching HOT-tuple reclamations, auto-analyze might never
|
|
|
|
trigger at all, even if all three numbers are exactly right,
|
|
|
|
because n_dead_tuples could hold steady.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Support ALTER TABLESPACE name SET/RESET (
|
|
|
|
tablespace_options ), currently supporting seq_page_cost and
|
|
|
|
random_page_cost as parameters.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>New faster implementation of VACUUM FULL. The old
|
|
|
|
idiom of using CLUSTER instead of VACUUM FULL for speed is
|
|
|
|
now obsolete.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add buffer access counters to
|
|
|
|
pg_stat_statements.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add some simple support and documentation for using
|
|
|
|
process-specific oom_adj settings to prevent the postmaster
|
|
|
|
from being OOM-killed on Linux systems.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Place tablespace directories in their own
|
|
|
|
subdirectory so pg_migrator can upgrade clusters without
|
|
|
|
renaming the tablespace directories.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Introduce Streaming Replication.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add pg_table_size() and pg_indexes_size() to
|
|
|
|
provide more user-friendly wrappers around the
|
|
|
|
pg_relation_size() function.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add pg_stat_reset_shared('bgwriter') to reset the
|
|
|
|
cluster-wide shared statistics of the bgwriter.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Replace ALTER TABLE ... SET STATISTICS DISTINCT
|
|
|
|
with a more general mechanism. Attributes can now have
|
|
|
|
options, just as relations and tablespaces do, and the
|
|
|
|
reloptions code is used to parse, validate, and store
|
|
|
|
them.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Fix longstanding gripe that we check for
|
|
|
|
0000000001.history at start of archive recovery, even when we
|
|
|
|
know it is never present.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Make standby server continuously retry restoring
|
|
|
|
the next WAL segment with restore_command, if the connection
|
|
|
|
to the primary server is lost. This ensures that the standby
|
|
|
|
can recover automatically, if the connection is lost for a
|
|
|
|
long time and standby falls behind so much that the required
|
|
|
|
WAL segments have been archived and deleted in the
|
|
|
|
master.</emphasis>
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
<emphasis>This also makes standby_mode useful without
|
|
|
|
streaming replication; the server will keep retrying
|
|
|
|
restore_command every few seconds until the trigger file is
|
|
|
|
found. That's the same basic functionality pg_standby
|
|
|
|
offers, but without the bells and whistles.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add functions to reset the statistics counter for a
|
|
|
|
single table/index or a single function.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Augment EXPLAIN output with more details on Hash
|
|
|
|
nodes.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Reindexing shared system catalogs is now fully
|
|
|
|
transactional and crash-safe.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Allow read-only connections during recovery, also
|
2009-12-19 21:33:12 +01:00
|
|
|
known as Hot Standby. This provides a built-in master-slave
|
2010-02-19 01:35:18 +01:00
|
|
|
replication solution.
|
2009-12-19 21:33:12 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Provide a parenthesized-options syntax for VACUUM, analogous to
|
2009-12-18 23:11:09 +01:00
|
|
|
that recently adopted for EXPLAIN. This will allow additional
|
|
|
|
options to be implemented in future without having to make them
|
|
|
|
fully-reserved keywords. The old syntax remains available for
|
2010-02-19 01:35:18 +01:00
|
|
|
existing options, however.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add support for an application_name parameter, which is displayed
|
|
|
|
in pg_stat_activity and recorded in log entries.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Fix longstanding problems in VACUUM caused by untimely
|
|
|
|
interruptions.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add YAML to list of EXPLAIN formats.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add an EXPLAIN (BUFFERS) option to show buffer-usage statistics.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add a hook to let loadable modules get control at ProcessUtility
|
2009-12-18 23:11:09 +01:00
|
|
|
execution, and use it to extend contrib/pg_stat_statements to track
|
2010-02-19 01:35:18 +01:00
|
|
|
utility commands.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add a Boolean server configuration parameter
|
2009-10-20 21:52:58 +02:00
|
|
|
"bonjour" to control whether a Bonjour-enabled
|
2009-12-18 23:11:09 +01:00
|
|
|
build actually attempts to advertise itself via Bonjour.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
When reloading postgresql.conf, log what parameters actually
|
|
|
|
changed.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Make it possibly to specify server configuration parameters
|
2009-10-21 21:43:06 +02:00
|
|
|
per user-database combination. Add a \drds command to psql to
|
2009-12-18 23:11:09 +01:00
|
|
|
display the settings.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Allow the collection of statistics on sequences.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-21 21:43:06 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Increase the maximum value of extra_float_digits to
|
2009-10-21 21:43:06 +02:00
|
|
|
3, and have pg_dump use that value when the backend is new
|
|
|
|
enough to allow it, because it is possible to need 3 extra
|
2009-12-18 23:11:09 +01:00
|
|
|
digits for float4 values (but not for float8 values).
|
2009-10-21 21:43:06 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add the ability to include the SQLSTATE error code of any error
|
|
|
|
messages in the PostgreSQL activity log with the new
|
|
|
|
log_line_prefix placeholder %e.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Show the exact value being complained of in
|
|
|
|
unique-constraint-violation error messages, including unique-index
|
|
|
|
build failures.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
|
|
|
<title>Security</title>
|
|
|
|
<itemizedlist>
|
2009-10-21 21:43:06 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add support for RADIUS authentication.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
When querying a table with child tables, do not check permissions
|
2009-12-18 23:11:09 +01:00
|
|
|
on the child tables, only on the parent table. The old behavior was
|
|
|
|
found to be useless and confusing in virtually all cases, and also
|
2010-02-19 01:35:18 +01:00
|
|
|
contrary to the SQL standard.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add a hook to CREATE/ALTER ROLE to allow an external module to
|
2009-12-18 23:11:09 +01:00
|
|
|
check the strength of database passwords, and create a sample
|
|
|
|
implementation of such a hook as a new contrib module
|
2010-02-19 01:35:18 +01:00
|
|
|
"passwordcheck".
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add large object access control.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Allow LDAP authentication to operate in search+bind
|
2009-12-18 23:11:09 +01:00
|
|
|
mode, meaning it does a search for the user in the directory
|
|
|
|
first, and then binds with the DN found for this user. This
|
|
|
|
allows for LDAP logins in scenarios where the DN of the user
|
|
|
|
cannot be determined simply by prefix and suffix, such as the
|
|
|
|
case where different users are located in different
|
|
|
|
containers. The old way of authentication can be
|
2010-02-19 01:35:18 +01:00
|
|
|
significantly faster, so it's kept as an option.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add ALTER DEFAULT PRIVILEGES command, which allows
|
2009-10-21 21:43:06 +02:00
|
|
|
users to adjust the privileges that will be applied to
|
2009-12-18 23:11:09 +01:00
|
|
|
subsequently-created objects.
|
2009-10-21 21:43:06 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Add GRANT/REVOKE ON ALL TABLES/SEQUENCES/FUNCTIONS IN SCHEMA.
|
|
|
|
This makes it easier to manage permissions on database objects.
|
2009-10-21 21:43:06 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Support "samehost" and "samenet" specifications
|
2009-10-21 21:43:06 +02:00
|
|
|
in pg_hba.conf. This allows users with dynamic server addresses to run
|
2009-12-18 23:11:09 +01:00
|
|
|
PostgreSQL without frequently modifying pg_hba.conf.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
New has_sequence_privilege() functions allow you to check sequence
|
|
|
|
privileges for a given ROLE.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
|
|
|
<title>Built-In Functions</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Fix 3-parameter form of bit substring() to throw
|
|
|
|
error for negative length, as required by SQL
|
|
|
|
standard.</emphasis>
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add get_bit/set_bit functions for bit strings,
|
|
|
|
paralleling those for bytea, and implement OVERLAY() for bit
|
|
|
|
strings and bytea.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add string_agg aggregate functions. The
|
|
|
|
one-argument version concatenates the input values into a
|
|
|
|
string. The two-argument version also does the same thing,
|
|
|
|
but inserts delimiters between elements.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Honor to_char() "FM" specification in YYY, YY, and
|
|
|
|
Y; it was already honored by YYYY.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Remove configuration parameter regex_flavor. It is now always
|
|
|
|
"advanced".
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Teach the regular expression functions to do case-insensitive
|
2009-12-18 23:11:09 +01:00
|
|
|
matching and locale-dependent character classification properly
|
|
|
|
when the database encoding is UTF8. This previously only worked
|
2009-12-19 03:38:54 +01:00
|
|
|
correctly for single-byte encodings. It is still broken for other
|
2010-02-19 01:35:18 +01:00
|
|
|
multibyte encodings.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Support POSIX-compatible interpretation of ? as well as {m,n}
|
|
|
|
and related constructs in SIMILAR TO, per SQL:2008.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
The to_char() formatting functions now supports EEEE (scientific
|
|
|
|
notation).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Use floor() not rint() when reducing precision of fractional
|
|
|
|
seconds in timestamp_trunc, timestamptz_trunc, and interval_trunc()
|
|
|
|
for the float-datetime case. This improves accuracy of time
|
|
|
|
calculations.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Fix ancient bug in handling of to_char() modifier 'TH', when used
|
|
|
|
with HH.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
2009-10-20 21:52:58 +02:00
|
|
|
<title>Data Types</title>
|
2009-08-18 00:14:44 +02:00
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Allow enums to be created with zero labels, for use
|
|
|
|
during binary upgrade.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
When doing "ARRAY[...]::domain", where domain is a domain
|
2009-12-18 23:11:09 +01:00
|
|
|
over an array type, we need to check domain constraints. Regression
|
2010-02-19 01:35:18 +01:00
|
|
|
introduced in 8.4.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Fix integer-to-bit-string conversions to handle the first
|
2009-12-18 23:11:09 +01:00
|
|
|
fractional byte correctly when the output bit width is wider than
|
2010-02-19 01:35:18 +01:00
|
|
|
the given integer by something other than a multiple of 8 bits.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Fix encoding handling in binary input function of xml type.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Tighten binary receive functions so that they reject values
|
|
|
|
that the text input functions don't accept either.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
New hex-string input and output format options for type bytea. Hex
|
|
|
|
output format is enabled by default, which is an incompatible
|
|
|
|
change. See the new bytea_output parameter if you need to restore
|
2009-08-18 00:14:44 +02:00
|
|
|
compatibility.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Adds prefix support for text search synonym dictionary, allowing
|
|
|
|
creation of synonyms on partial matches.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
|
|
|
<title>Server Tools</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
initdb now selects the encoding SQL_ASCII when the locale specifies
|
|
|
|
US-ASCII. This case previously failed.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add init[db] option to pg_ctl.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
It is now reasonably safe to use pg_ctl to start
|
|
|
|
the postmaster from a boot-time script.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<para>
|
|
|
|
pg_dump/pg_restore --clean now drops large objects.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-10-20 21:52:58 +02:00
|
|
|
Modify parallel pg_restore ordering logic to avoid a potential
|
2009-08-18 00:14:44 +02:00
|
|
|
O(N^2) slowdown for some complex databases.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
2009-12-19 03:38:54 +01:00
|
|
|
<sect3>
|
|
|
|
<title>libpq</title>
|
|
|
|
<itemizedlist>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add user-specific .pg_service.conf file.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add new escaping functions PQescapeLiteral and
|
|
|
|
PQescapeIdentifier.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Introduce two new libpq connection functions,
|
|
|
|
PQconnectdbParams and PQconnectStartParams, which are
|
|
|
|
analogous to PQconnectdb and PQconnectStart respectively, but
|
|
|
|
accept two NULL-terminated arrays, keywords and values,
|
|
|
|
rather than conninfo strings. This avoids the need to build
|
|
|
|
the conninfo string in cases where it might be inconvenient
|
|
|
|
to do so.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Throw error when a specified connection service name is not
|
|
|
|
found in pg_service.conf, instead of ignoring it.
|
2009-12-19 03:38:54 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Make libpq reject non-numeric and out-of-range port numbers with a
|
|
|
|
suitable error message.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
2009-08-18 00:14:44 +02:00
|
|
|
<sect3>
|
|
|
|
<title>psql</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Allow psql variables to be interpolated with
|
|
|
|
literal or identifier escaping.</emphasis>
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
In psql, show view definition only with \d+, not with \d.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
In psql, ignore UTF-8-encoded Unicode byte-order mark at the
|
|
|
|
beginning of a file if the client encoding is UTF-8.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Improve psql's tabular display of wrapped-around data by inserting
|
2009-12-18 23:11:09 +01:00
|
|
|
markers in the formerly-always-blank columns just to left and right
|
|
|
|
of the data. "pset linestyle old-ascii" is added to make
|
2010-02-19 01:35:18 +01:00
|
|
|
the previous behavior available if anyone really wants it.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Simplify psql's new linestyle behavior to default to
|
2009-12-18 23:11:09 +01:00
|
|
|
linestyle=ascii all the time, rather than hoping we can tell
|
2010-02-19 01:35:18 +01:00
|
|
|
whether the terminal supports UTF-8 characters.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Implement significantly saner behavior when two or
|
|
|
|
more psql sessions overlap in their use of the history file.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Add "pset linestyle ascii/unicode" option to psql,
|
2009-10-20 21:52:58 +02:00
|
|
|
allowing our traditional ASCII-art style of table output to
|
|
|
|
be upgraded to use Unicode box drawing characters if
|
2009-12-18 23:11:09 +01:00
|
|
|
desired.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Have \d show child tables that inherit from the specified parent
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
psql now shows the index methods in \di
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
2010-02-19 01:35:18 +01:00
|
|
|
|
2009-08-18 00:14:44 +02:00
|
|
|
<sect3>
|
|
|
|
<title>Procedural Languages</title>
|
2010-02-19 01:35:18 +01:00
|
|
|
<sect4>
|
|
|
|
<title>PL/pgSQL</title>
|
2009-08-18 00:14:44 +02:00
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add "USING expressions" option to PL/pgSQL's OPEN
|
|
|
|
cursor FOR EXECUTE.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
PL/pgSQL is installed by default.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-21 21:43:06 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Remove PL/pgSQL's RENAME declaration, which has
|
2009-12-18 23:11:09 +01:00
|
|
|
bizarre and mostly nonfunctional behavior, and is so little
|
|
|
|
used that no one has been interested in fixing it. To ensure
|
|
|
|
that possible uses are covered, remove the ALIAS declaration's
|
|
|
|
arbitrary restriction that only $n identifiers can be
|
2010-02-19 01:35:18 +01:00
|
|
|
aliased.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
The PL/pgSQL parser and scanner were reworked to behave much more
|
|
|
|
sanely:
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
A variable reference will only be recognized where it can validly
|
2009-12-18 23:11:09 +01:00
|
|
|
go, ie, a place where a column value or parameter would be legal,
|
|
|
|
instead of the former behavior that would replace any textual match
|
|
|
|
including table names and column aliases (leading to syntax errors
|
2010-02-19 01:35:18 +01:00
|
|
|
later on).
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
When a name could refer either to a PL/pgSQL variable or a
|
2009-12-19 03:38:54 +01:00
|
|
|
table column, PL/pgSQL formerly always assumed the variable was
|
|
|
|
meant, sometimes resulting in surprising behavior. Now, PL/pgSQL
|
|
|
|
can assume the variable is meant, or assume the table column is
|
|
|
|
meant, or throw an error in ambiguous cases. For safety the default
|
2009-12-19 06:37:01 +01:00
|
|
|
is to throw error. To configure this see <link
|
2010-02-19 01:35:18 +01:00
|
|
|
linkend="plpgsql-var-subst">the PL/pgSQL documentation</link>.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Error reporting is much nicer: it no longer shows edited
|
2009-12-19 03:38:54 +01:00
|
|
|
versions of statements that look significantly different from what
|
2010-02-19 01:35:18 +01:00
|
|
|
you wrote.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Note that this change affects the set of keywords that are
|
2009-12-19 03:38:54 +01:00
|
|
|
reserved in PL/pgSQL (i.e., cannot be the name of a PL/pgSQL
|
2009-12-19 06:37:01 +01:00
|
|
|
variable). Now, all keywords shown as reserved in <link
|
|
|
|
linkend="sql-keywords-appendix">Appendix C</link> are reserved for
|
|
|
|
PL/pgSQL purposes as well. However, many PL/pgSQL-only keywords
|
|
|
|
that were formerly treated as reserved no longer are. As in regular
|
|
|
|
SQL, you can double-quote a variable's name if you want to use a
|
2010-02-19 01:35:18 +01:00
|
|
|
name that conflicts with a reserved keyword.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
PL/pgSQL IN parameters now accept value assignments.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Allow cursor commands MOVE FORWARD n, MOVE BACKWARD n,
|
|
|
|
MOVE FORWARD ALL, MOVE BACKWARD ALL in PL/pgSQL.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-02-19 01:35:18 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
PL/pgSQL functions can now better cope with row types
|
|
|
|
containing dropped columns.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>PL/Perl</title>
|
|
|
|
<itemizedlist>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add utility functions to PL/Perl: quote_literal,
|
|
|
|
quote_nullable, quote_ident, encode_bytea, decode_bytea,
|
|
|
|
looks_like_number, encode_array_literal,
|
|
|
|
encode_array_constructor.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add plperl.on_plperl_init, plperl.on_plperlu_init,
|
|
|
|
and plperl.on_init settings for startup code.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Allow (ineffective) use of "require". If the
|
|
|
|
required module is not already loaded then it dies. So "use
|
|
|
|
strict;" now works in PL/Perl.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Pre-load the feature module if Perl >= 5.10.
|
|
|
|
So "use feature :5.10;" now works in PL/Perl.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Stored procedure subs are now given names. The
|
|
|
|
names are not visible in ordinary use, but they make tools
|
|
|
|
like Devel::NYTProf and Devel::Cover much more
|
|
|
|
useful.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Handle END blocks in PL/Perl.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-12-18 23:11:09 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Clean up package namespace use and use of Safe.</emphasis>
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Change log level of Perl warnings from NOTICE to
|
|
|
|
WARNING.</emphasis>
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add support for anonymous code blocks (DO blocks) to PL/Perl.
|
2009-10-21 21:43:06 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Improve error context reporting in PL/Perl, for
|
|
|
|
easier debugging.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Convert a Perl array to a PostgreSQL array when returned by
|
|
|
|
set-returning functions as well as non-SRFs.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2010-02-19 01:35:18 +01:00
|
|
|
</itemizedlist>
|
|
|
|
</sect4>
|
|
|
|
|
|
|
|
<sect4>
|
|
|
|
<title>PL/Python</title>
|
|
|
|
<itemizedlist>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Improved printing of Python exceptions in
|
|
|
|
PL/Python.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add PL/Python DO handler.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Support arrays as parameters and return values of PL/Python
|
|
|
|
functions.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add Python 3 support to PL/Python. It behaves more or less
|
|
|
|
unchanged compared to Python 2, but the new language variant is
|
|
|
|
called plpython3u.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Fix/improve bytea and boolean support in PL/Python. Data type
|
|
|
|
conversion into and out of PL/Python previously went through
|
|
|
|
an intermediate string representation, which caused various
|
|
|
|
discrepancies especially with bytea and boolean data. This is
|
|
|
|
now fixed by converting the values directly.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
PL/Python now accepts Unicode objects where it previously
|
|
|
|
only accepted string objects (for example, as return
|
|
|
|
value). Unicode objects are converted to the PostgreSQL
|
|
|
|
server encoding as necessary.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-10-20 21:52:58 +02:00
|
|
|
Improve error context reporting in PL/Python, for easier
|
2009-08-18 00:14:44 +02:00
|
|
|
debugging.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-10-20 21:52:58 +02:00
|
|
|
Greatly expand the regression testing for PL/Python.
|
2009-08-18 00:14:44 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
2010-02-19 01:35:18 +01:00
|
|
|
</sect4>
|
2009-08-18 00:14:44 +02:00
|
|
|
</sect3>
|
2010-02-19 01:35:18 +01:00
|
|
|
|
2009-08-18 00:14:44 +02:00
|
|
|
<sect3>
|
|
|
|
<title>Additional Supplied Modules</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add query text to auto_explain output.</emphasis>
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
2010-02-19 01:35:18 +01:00
|
|
|
</listitem>
|
|
|
|
<listitem>
|
2009-12-18 23:11:09 +01:00
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Add \shell and \setshell meta commands to pgbench.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
\shell runs an external shell command. \setshell
|
|
|
|
does the same and assigns the result to a variable.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Multiple improvements in contrib/hstore, including
|
2009-10-21 21:43:06 +02:00
|
|
|
raising limits on keys and values, conversions to and from
|
2009-12-18 23:11:09 +01:00
|
|
|
records and arrays, and support for GROUP BY and DISTINCT.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
pgbench is now multi-threaded, allowing it to use multiple CPU's
|
|
|
|
for its client connections, and to do more realistic workload
|
|
|
|
testing.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Added the ability to retrieve asynchronous notifications using
|
|
|
|
dblink, via the addition of the function dblink_get_notify().
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Added matchorig, matchsynonyms, and keepsynonyms options to
|
|
|
|
contrib/dict_xsyn.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-19 09:54:21 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Added contrib/unaccent.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
2009-10-20 21:52:58 +02:00
|
|
|
<sect3>
|
2010-02-19 01:35:18 +01:00
|
|
|
<title>ECPG</title>
|
2009-10-21 21:43:06 +02:00
|
|
|
<itemizedlist>
|
2009-12-18 23:11:09 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add sqlda support in both native and compatibility
|
|
|
|
mode.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Fix SQL3 type return value: For non-SQL3 types ECPG
|
|
|
|
used to return -OID. This will break if there are enough OIDs
|
|
|
|
to fill the namespace. Therefore we play it safe and return
|
|
|
|
0 if there is no OID->SQL3 type mapping available.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Make char the default sqlda type.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add DESCRIBE [OUTPUT] statement.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add out-of-scope cursor support to native mode.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Refactor ECPG grammar so that it uses the core grammar's
|
2009-12-18 23:11:09 +01:00
|
|
|
unreserved_keyword list, minus a few specific words that have to be
|
2010-02-19 01:35:18 +01:00
|
|
|
treated specially. This de-reserves a number of words in ECPG.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
Added dynamic cursor names to ECPG.
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Add ECPG function that returns the current transaction status.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Make ECPG more robust against applications freeing strings.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
ECPG now includes a STRING datatype for Informix compatibility
|
|
|
|
mode.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
2009-08-18 18:54:12 +02:00
|
|
|
<sect3>
|
|
|
|
<title>Ports</title>
|
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Add basic build support for Visual Studio 2008,
|
|
|
|
without resorting to generating the build files for 2005 and
|
|
|
|
then converting them.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Added support for 64-bit Windows platforms.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Disable triggering failover with a signal in pg_standby on Windows.
|
|
|
|
It never really worked before anyway.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Change the WIN32 API version to be 5.01 (Windows XP), to
|
|
|
|
bring in the proper IPv6 headers in newer SDKs.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Write to the Windows eventlog in UTF-16, converting the
|
|
|
|
message encoding as necessary.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Replace use of the long-deprecated Bonjour API
|
|
|
|
DNSServiceRegistrationCreate with the not-so-deprecated
|
|
|
|
DNSServiceRegister. The new code will fail on Mac OS X
|
|
|
|
releases before 10.3.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
2009-08-18 18:54:12 +02:00
|
|
|
<para>
|
|
|
|
Reserve the shared memory region during backend startup on Windows,
|
|
|
|
so that memory allocated by starting third party DLLs doesn't end
|
|
|
|
up conflicting with it. Hopefully this solves the long-time issue
|
|
|
|
with "could not reattach to shared memory" errors on
|
|
|
|
Win32.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add s_lock support for SuperH architecture (not well tested).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
2009-08-18 00:14:44 +02:00
|
|
|
<sect3>
|
2009-12-18 23:11:09 +01:00
|
|
|
<title>Source Code, Build Options</title>
|
2009-08-18 00:14:44 +02:00
|
|
|
<itemizedlist>
|
2009-10-20 21:52:58 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
2010-02-19 01:35:18 +01:00
|
|
|
<emphasis>Improve PGXS makefile system to allow the module's
|
|
|
|
makefile to specify where to install DATA and DOCS files.
|
|
|
|
This is mainly intended to allow versioned installation, eg,
|
|
|
|
install into contrib/fooM.N/ rather than directly into
|
|
|
|
contrib/.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Get rid of the need for manual maintenance of the
|
|
|
|
initial contents of pg_attribute, by having genbki.pl derive
|
|
|
|
the information from the various catalog header files. This
|
|
|
|
greatly simplifies modification of the "bootstrapped"
|
|
|
|
catalogs. This patch finally kills genbki.sh and
|
|
|
|
Gen_fmgrtab.sh; we now rely entirely on Perl scripts for
|
|
|
|
those build steps. To avoid creating a Perl build dependency
|
|
|
|
where there was not one before, they will be built and
|
|
|
|
shipped in tarballs.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Move the default configuration for the MSVC build
|
|
|
|
system to config_default.pl, and allow using config.pl to
|
|
|
|
override the defaults.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Make configure check the version of Perl we're
|
|
|
|
building with, and reject versions < 5.8.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Remove all support for working around on systems
|
|
|
|
that don't provide a working 64-bit integer type.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
<emphasis>Add new make targets "world", "install-world" and
|
|
|
|
"installcheck-world" to build, install and check just about
|
|
|
|
everything. In addition to everything built installed and
|
|
|
|
tested by all, install and installcheck targets, these build
|
|
|
|
HTML documentation, build and test contrib, and test
|
|
|
|
procedural languages and ECPG.</emphasis>
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
configure --enable-thread-safety is now the default (but can still
|
|
|
|
be turned off).
|
2009-12-18 23:11:09 +01:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Fix inclusions of readline/editline header files so that we
|
2009-10-20 21:52:58 +02:00
|
|
|
only attempt to #include the version of history.h that is in
|
|
|
|
the same directory as the readline.h we are using. This
|
|
|
|
avoids problems in some scenarios where both readline and
|
2009-12-18 23:11:09 +01:00
|
|
|
editline are installed.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
2009-12-18 23:11:09 +01:00
|
|
|
Derived files that are shipped in the distribution used to be
|
2009-10-20 21:52:58 +02:00
|
|
|
built in the source directory even for out-of-tree
|
2009-12-19 03:38:54 +01:00
|
|
|
builds. They are now built in the build tree. This
|
2009-12-18 23:11:09 +01:00
|
|
|
should be more convenient for certain developers' workflows.
|
2009-10-20 21:52:58 +02:00
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-12-19 03:38:54 +01:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Functions which conflict with C++ reserved words have been renamed,
|
|
|
|
making backend header files now safe to use with C++ libraries.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Add man pages for SPI functions.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
2009-08-18 00:14:44 +02:00
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Upgrade to Autoconf 2.63 (not relevant to users of distribution
|
|
|
|
tarballs).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Minimum version of Flex is now 2.5.31, to support reentrant
|
|
|
|
scanners (not relevant to users of distribution tarballs).
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Documentation build rules have been improved. The generated
|
|
|
|
documentation files are now shipped "loose", not in
|
|
|
|
sub-tarballs.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
New toolchain to generate man pages. From now on, the man pages
|
|
|
|
will be current in every release.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Code-coverage testing support now extends to the entire source
|
|
|
|
tree, not only src/backend/.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
<listitem>
|
|
|
|
<para>
|
|
|
|
Make the core scanner re-entrant, along with additional fixes that
|
|
|
|
will let it be used directly by PL/pgSQL.
|
|
|
|
</para>
|
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</sect3>
|
|
|
|
</sect2>
|
|
|
|
</sect1>
|