]> granicus.if.org Git - postgresql/log
postgresql
15 years agoDept of second thoughts: my first cut at supporting "x IS NOT NULL" btree
Tom Lane [Sun, 3 Jan 2010 05:39:08 +0000 (05:39 +0000)]
Dept of second thoughts: my first cut at supporting "x IS NOT NULL" btree
indexscans would do the wrong thing if index_rescan() was called with a
NULL instead of a new set of scankeys and the index was DESC order,
because sk_strategy would not get flipped a second time.  I think
that those provisions for a NULL argument are dead code now as far as the
core backend goes, but possibly somebody somewhere is still using it.
In any case, this refactoring seems clearer, and it's definitely shorter.

15 years agoMake ssize_t 64-bit on Win64, for compatibility with for example plpython.
Magnus Hagander [Sat, 2 Jan 2010 22:47:37 +0000 (22:47 +0000)]
Make ssize_t 64-bit on Win64, for compatibility with for example plpython.

15 years agoAdd missing schema-qualification in tab completion query.
Tom Lane [Sat, 2 Jan 2010 21:28:46 +0000 (21:28 +0000)]
Add missing schema-qualification in tab completion query.

15 years agoFix similar_escape() to convert parentheses to non-capturing style.
Tom Lane [Sat, 2 Jan 2010 20:59:16 +0000 (20:59 +0000)]
Fix similar_escape() to convert parentheses to non-capturing style.
This is needed to avoid unwanted interference with SUBSTRING behavior,
as per bug #5257 from Roman Kononov.  Also, add some basic intelligence
about character classes (bracket expressions) since we now have several
behaviors that aren't appropriate inside a character class.

As with the previous patch in this area, I'm reluctant to back-patch
since it might affect applications that are relying on the prior
behavior.

15 years agocheck_exclusion_constraint didn't actually work correctly for index
Tom Lane [Sat, 2 Jan 2010 17:53:57 +0000 (17:53 +0000)]
check_exclusion_constraint didn't actually work correctly for index
expressions: FormIndexDatum requires the estate's scantuple to already point
at the tuple the values are supposedly being extracted from.  Adjust test
case so that this type of confusion will be exposed.
Per report from hubert depesz lubaczewski.

15 years agoUpdate copyright for the year 2010.
Bruce Momjian [Sat, 2 Jan 2010 16:58:17 +0000 (16:58 +0000)]
Update copyright for the year 2010.

15 years agoSilence compiler warning about size of size_t being larger than the result
Magnus Hagander [Sat, 2 Jan 2010 15:18:42 +0000 (15:18 +0000)]
Silence compiler warning about size of size_t being larger than the result
variable it's stored in. We know this can never happen. Per discussion.

15 years agoSet proper sizes for size_t and void* on 64-bit Windows builds.
Magnus Hagander [Sat, 2 Jan 2010 13:56:37 +0000 (13:56 +0000)]
Set proper sizes for size_t and void* on 64-bit Windows builds.

Tsutomu Yamada

15 years agoSupport 64-bit shared memory when building on 64-bit Windows.
Magnus Hagander [Sat, 2 Jan 2010 12:18:45 +0000 (12:18 +0000)]
Support 64-bit shared memory when building on 64-bit Windows.

Tsutomu Yamada

15 years agoFix one more cast for _open_osfhandle().
Magnus Hagander [Sat, 2 Jan 2010 12:01:29 +0000 (12:01 +0000)]
Fix one more cast for _open_osfhandle().

Tsutomu Yamada

15 years agoFix cast for _open_osfhandle().
Magnus Hagander [Sat, 2 Jan 2010 12:00:08 +0000 (12:00 +0000)]
Fix cast for _open_osfhandle().

Tsutomu Yamada

15 years agoAdd an "argisrow" field to NullTest nodes, following a plan made way back in
Tom Lane [Fri, 1 Jan 2010 23:03:10 +0000 (23:03 +0000)]
Add an "argisrow" field to NullTest nodes, following a plan made way back in
8.2beta but never carried out.  This avoids repetitive tests of whether the
argument is of scalar or composite type.  Also, be a bit more paranoid about
composite arguments in some places where we previously weren't checking.

15 years agoSupport "x IS NOT NULL" clauses as indexscan conditions. This turns out
Tom Lane [Fri, 1 Jan 2010 21:53:49 +0000 (21:53 +0000)]
Support "x IS NOT NULL" clauses as indexscan conditions.  This turns out
to be just a minor extension of the previous patch that made "x IS NULL"
indexable, because we can treat the IS NOT NULL condition as if it were
"x < NULL" or "x > NULL" (depending on the index's NULLS FIRST/LAST option),
just like IS NULL is treated like "x = NULL".  Aside from any possible
usefulness in its own right, this is an important improvement for
index-optimized MAX/MIN aggregates: it is now reliably possible to get
a column's min or max value cheaply, even when there are a lot of nulls
cluttering the interesting end of the index.

15 years agoSilence compiler warning on 64-bit windows build
Magnus Hagander [Fri, 1 Jan 2010 19:57:07 +0000 (19:57 +0000)]
Silence compiler warning on 64-bit windows build

15 years agoDetect a 64-bit build environment on Windows, and generate the appropriate
Magnus Hagander [Fri, 1 Jan 2010 17:34:25 +0000 (17:34 +0000)]
Detect a 64-bit build environment on Windows, and generate the appropriate
project files.

Based on the work of Tsutomu Yamada, but much refactored.

15 years agoDelete solution cache file on clean, if it exists.
Magnus Hagander [Fri, 1 Jan 2010 16:58:53 +0000 (16:58 +0000)]
Delete solution cache file on clean, if it exists.

15 years agoUpdate SQL features supported list
Peter Eisentraut [Fri, 1 Jan 2010 16:54:48 +0000 (16:54 +0000)]
Update SQL features supported list

15 years agoMake the win32 putenv() override update *all* present versions of the
Magnus Hagander [Fri, 1 Jan 2010 14:57:16 +0000 (14:57 +0000)]
Make the win32 putenv() override update *all* present versions of the
MSVCRxx runtime, not just the current + Visual Studio 6 (MSVCRT). Clearly
there can be an almost unlimited number of runtimes loaded at the same
time.

Per report from Hiroshi Inoue

15 years agoSuppress compiler warning, per buildfarm member narwhal
Tom Lane [Thu, 31 Dec 2009 22:11:10 +0000 (22:11 +0000)]
Suppress compiler warning, per buildfarm member narwhal

15 years agoSuppress compiler warning (pid_t isn't int everywhere)
Tom Lane [Thu, 31 Dec 2009 22:07:36 +0000 (22:07 +0000)]
Suppress compiler warning (pid_t isn't int everywhere)

15 years agoAdd missing 'static' tag.
Tom Lane [Thu, 31 Dec 2009 21:47:12 +0000 (21:47 +0000)]
Add missing 'static' tag.

15 years agoRedefine Datum as uintptr_t, instead of unsigned long.
Tom Lane [Thu, 31 Dec 2009 19:41:37 +0000 (19:41 +0000)]
Redefine Datum as uintptr_t, instead of unsigned long.

This is more in keeping with modern practice, and is a first step towards
porting to Win64 (which has sizeof(pointer) > sizeof(long)).

Tsutomu Yamada, Magnus Hagander, Tom Lane

15 years agoUpdate SQL features list for aggregate ORDER BY support
Peter Eisentraut [Thu, 31 Dec 2009 14:51:16 +0000 (14:51 +0000)]
Update SQL features list for aggregate ORDER BY support

15 years agoAdd information_schema.triggered_update_columns
Peter Eisentraut [Thu, 31 Dec 2009 14:41:23 +0000 (14:41 +0000)]
Add information_schema.triggered_update_columns

This reflects the recently added support for triggers on columns.

15 years agoenable examples to compile on Windows. patch from Hiroshi Saito.
Andrew Dunstan [Thu, 31 Dec 2009 00:16:47 +0000 (00:16 +0000)]
enable examples to compile on Windows. patch from Hiroshi Saito.

15 years agoFill in information schema column for trigger WHEN condition
Peter Eisentraut [Wed, 30 Dec 2009 22:48:10 +0000 (22:48 +0000)]
Fill in information schema column for trigger WHEN condition

15 years agoDept of second thoughts: recursive case in ANALYZE shouldn't emit a
Tom Lane [Wed, 30 Dec 2009 21:21:33 +0000 (21:21 +0000)]
Dept of second thoughts: recursive case in ANALYZE shouldn't emit a
pgstats message.  This might need to be done differently later, but
with the current logic that's what should happen.

15 years agoRevise pgstat's tracking of tuple changes to improve the reliability of
Tom Lane [Wed, 30 Dec 2009 20:32:14 +0000 (20:32 +0000)]
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.

To fix, replace last_anl_tuples with an accurately tracked count of the total
number of committed tuple inserts + updates + deletes since the last ANALYZE
on the table.  This can still be compared to the same threshold as before, but
it's much more trustworthy than the old computation.  Tracking this requires
one more intra-transaction counter per modified table within backends, but no
additional memory space in the stats collector.  There probably isn't any
measurable speed difference; if anything it might be a bit faster than before,
since I was able to eliminate some per-tuple arithmetic operations in favor of
adding sums once per (sub)transaction.

Also, simplify the logic around pgstat vacuum and analyze reporting messages
by not trying to fold VACUUM ANALYZE into a single pgstat message.

The original thought behind this patch was to allow scheduling of analyzes
on parent tables by artificially inflating their changes_since_analyze count.
I've left that for a separate patch since this change seems to stand on its
own merit.

15 years agoUpdate SQL conformance: search conditions on triggers are supported
Peter Eisentraut [Wed, 30 Dec 2009 19:37:47 +0000 (19:37 +0000)]
Update SQL conformance: search conditions on triggers are supported

15 years agoRevert makefile refactoring (version 1.123) because it doesn't work
Peter Eisentraut [Wed, 30 Dec 2009 13:48:52 +0000 (13:48 +0000)]
Revert makefile refactoring (version 1.123) because it doesn't work
when building several files at once (e.g.,
gmake postgres-A4.pdf postgres-US.pdf).

15 years agoExclude part of the product name string that is localized in Japanese versions
Magnus Hagander [Wed, 30 Dec 2009 12:26:41 +0000 (12:26 +0000)]
Exclude part of the product name string that is localized in Japanese versions
of MSVC when detecting MSVC version.

Hiroshi Inoue

15 years agoReset minRecoveryPoint at checkpoints, so that we don't uselessly update
Heikki Linnakangas [Wed, 30 Dec 2009 08:37:21 +0000 (08:37 +0000)]
Reset minRecoveryPoint at checkpoints, so that we don't uselessly update
it in the control file at crash recovery following an archive recovery.

Per Fujii Masao and subsequent discussion.

15 years agoSet errno to zero before invoking SSL_read or SSL_write. It appears that
Tom Lane [Wed, 30 Dec 2009 03:45:46 +0000 (03:45 +0000)]
Set errno to zero before invoking SSL_read or SSL_write.  It appears that
at least in some Windows versions, these functions are capable of returning
a failure indication without setting errno.  That puts us into an infinite
loop if the previous value happened to be EINTR.  Per report from Brendan
Hill.

Back-patch to 8.2.  We could take it further back, but since this is only
known to be an issue on Windows and we don't support Windows before 8.2,
it does not seem worth the trouble.

15 years agoReject invalid input in int2vectorin.
Robert Haas [Wed, 30 Dec 2009 01:29:22 +0000 (01:29 +0000)]
Reject invalid input in int2vectorin.

Since the int2vector type is intended only for internal use, this patch doesn't
worry about prettifying the error messages, which has the fringe benefit of
avoiding creating additional translatable strings.  For a type intended to be
used by end-users, we would want to do better, but the approach taken here
seems like the correct trade-off for this case.

Caleb Welton

15 years agoAdd an index on pg_inherits.inhparent, and use it to avoid seqscans in
Tom Lane [Tue, 29 Dec 2009 22:00:14 +0000 (22:00 +0000)]
Add an index on pg_inherits.inhparent, and use it to avoid seqscans in
find_inheritance_children().  This is a complete no-op in databases without
any inheritance.  In databases where there are just a few entries in
pg_inherits, it could conceivably be a small loss.  However, in databases with
many inheritance parents, it can be a big win.

15 years agoAdd the ability to store inheritance-tree statistics in pg_statistic,
Tom Lane [Tue, 29 Dec 2009 20:11:45 +0000 (20:11 +0000)]
Add the ability to store inheritance-tree statistics in pg_statistic,
and teach ANALYZE to compute such stats for tables that have subclasses.
Per my proposal of yesterday.

autovacuum still needs to be taught about running ANALYZE on parent tables
when their subclasses change, but the feature is useful even without that.

15 years agoPrevious fix for temporary file management broke returning a set from
Heikki Linnakangas [Tue, 29 Dec 2009 17:40:59 +0000 (17:40 +0000)]
Previous fix for temporary file management broke returning a set from
PL/pgSQL function within an exception handler. Make sure we use the right
resource owner when we create the tuplestore to hold returned tuples.

Simplify tuplestore API so that the caller doesn't need to be in the right
memory context when calling tuplestore_put* functions. tuplestore.c
automatically switches to the memory context used when the tuplestore was
created. Tuplesort was already modified like this earlier. This patch also
removes the now useless MemoryContextSwitch calls from callers.

Report by Aleksei on pgsql-bugs on Dec 22 2009. Backpatch to 8.1, like
the previous patch that broke this.

15 years agoSmall wording improvement and clarification in PL/pgSQL trigger documentation
Peter Eisentraut [Mon, 28 Dec 2009 19:11:51 +0000 (19:11 +0000)]
Small wording improvement and clarification in PL/pgSQL trigger documentation

15 years agoRemove PGDLLIMPORT used for binary upgrade; must be on the externs, per Tom.
Bruce Momjian [Mon, 28 Dec 2009 18:49:05 +0000 (18:49 +0000)]
Remove PGDLLIMPORT used for binary upgrade;  must be on the externs, per Tom.

15 years agoAdd PGDLLIMPORT for binary_upgrade global variables so shared object
Bruce Momjian [Mon, 28 Dec 2009 18:39:03 +0000 (18:39 +0000)]
Add PGDLLIMPORT for binary_upgrade global variables so shared object
libraries can access them.

15 years agoRemove non-ascii characters from source code.
Bruce Momjian [Mon, 28 Dec 2009 18:09:44 +0000 (18:09 +0000)]
Remove non-ascii characters from source code.

15 years agoAvoid memory leak if pgstat_vacuum_stat is interrupted partway through.
Tom Lane [Sun, 27 Dec 2009 19:40:07 +0000 (19:40 +0000)]
Avoid memory leak if pgstat_vacuum_stat is interrupted partway through.
The temporary hash tables made by pgstat_collect_oids should be allocated
in a short-term memory context, which is not the default behavior of
hash_create.  Noted while looking through hash_create calls in connection
with Robert Haas' recent complaint.

This is a pre-existing bug, but it doesn't seem important enough to
back-patch.  The hash table is not so large that it would matter unless this
happened many times within a session, which seems quite unlikely.

15 years agoRemove a couple of unnecessary calls of CreateCacheMemoryContext. These
Tom Lane [Sun, 27 Dec 2009 18:55:52 +0000 (18:55 +0000)]
Remove a couple of unnecessary calls of CreateCacheMemoryContext.  These
probably got there via blind copy-and-paste from one of the legitimate
callers, so rearrange and comment that code a bit to make it clearer that
this isn't a necessary prerequisite to hash_create.  Per observation
from Robert Haas.

15 years agoRemove now unreferenced variable.
Magnus Hagander [Sun, 27 Dec 2009 16:11:28 +0000 (16:11 +0000)]
Remove now unreferenced variable.

15 years agoIf the MSVCRT module is not found in the current binary, proceed to update
Magnus Hagander [Sun, 27 Dec 2009 16:01:39 +0000 (16:01 +0000)]
If the MSVCRT module is not found in the current binary, proceed to update
system and local environments anyway, instead of aborting. (This will
happen in a MSVC build with no or very few external libraries linked in)

15 years agoAdd backend and pg_dump code to allow preservation of pg_enum oids, for
Bruce Momjian [Sun, 27 Dec 2009 14:50:46 +0000 (14:50 +0000)]
Add backend and pg_dump code to allow preservation of pg_enum oids, for
use in binary upgrades.

Bump catalog version for detection by pg_migrator of new backend API.

15 years agoZero-label enums:
Bruce Momjian [Sat, 26 Dec 2009 16:55:21 +0000 (16:55 +0000)]
Zero-label enums:

Allow enums to be created with zero labels, for use during binary upgrade.

15 years agoFix brain fade in join-removal patch: a pushed-down clause in the outer join's
Tom Lane [Fri, 25 Dec 2009 17:11:32 +0000 (17:11 +0000)]
Fix brain fade in join-removal patch: a pushed-down clause in the outer join's
restrict list is not just something to ignore, it's actually grounds to
abandon the optimization entirely.  Per bug #5255 from Matteo Beccati.

15 years agoAdd missing <indexterm><primary>...</primary>...</indexterm> tags for a couple
Robert Haas [Fri, 25 Dec 2009 01:09:31 +0000 (01:09 +0000)]
Add missing <indexterm><primary>...</primary>...</indexterm> tags for a couple
of HS-related parameters.

Fujii Masao

15 years agoUpgrade to latest ppport.h. Patch from Tim Bunce.
Andrew Dunstan [Fri, 25 Dec 2009 00:24:59 +0000 (00:24 +0000)]
Upgrade to latest ppport.h. Patch from Tim Bunce.

15 years agoTry to improve the clarity of the psql documentation for the \d family of
Tom Lane [Thu, 24 Dec 2009 23:36:39 +0000 (23:36 +0000)]
Try to improve the clarity of the psql documentation for the \d family of
commands, as per recent discussion.  Includes suggestions from Adrian Klaver
and Filip Rembialkowski.

15 years agoRename EnumValuesCreate() single-letter variable names to useful
Bruce Momjian [Thu, 24 Dec 2009 22:17:58 +0000 (22:17 +0000)]
Rename EnumValuesCreate() single-letter variable names to useful
variable names.

15 years agoBinary upgrade:
Bruce Momjian [Thu, 24 Dec 2009 22:09:24 +0000 (22:09 +0000)]
Binary upgrade:

Modify pg_dump --binary-upgrade and add backend support routines to
support the preservation of pg_type oids when doing a binary upgrade.
This allows user-defined composite types and arrays to be binary
upgraded.

15 years agoFix wrong WAL info value generated when gistContinueInsert() performs an
Tom Lane [Thu, 24 Dec 2009 17:52:04 +0000 (17:52 +0000)]
Fix wrong WAL info value generated when gistContinueInsert() performs an
index page split.  This would result in index corruption, or even more likely
an error during WAL replay, if we were unlucky enough to crash during
end-of-recovery cleanup after having completed an incomplete GIST insertion.

Yoichi Hirai

15 years agoRevert brainfart: Of course the wildcard only works in GNU make itself.
Peter Eisentraut [Wed, 23 Dec 2009 19:42:15 +0000 (19:42 +0000)]
Revert brainfart: Of course the wildcard only works in GNU make itself.
Instead, add a few targets that were missing.

15 years agoReplace target list by a wildcard, so that this workaround makefile
Peter Eisentraut [Wed, 23 Dec 2009 19:17:45 +0000 (19:17 +0000)]
Replace target list by a wildcard, so that this workaround makefile
also works transparently for lesser used targets.

15 years agoAllow the index name to be omitted in CREATE INDEX, causing the system to
Tom Lane [Wed, 23 Dec 2009 17:41:45 +0000 (17:41 +0000)]
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.
(My recent changes to the index naming logic have helped to ensure that this
will be a reasonable choice.)  Per a suggestion from Peter.

A necessary side-effect is to promote CONCURRENTLY to type_func_name_keyword
status, ie, it can't be a table/column/index name anymore unless quoted.
This is not all bad, since we have heard more than once of people typing
CREATE INDEX CONCURRENTLY ON foo (...) and getting a normal index build of
an index named "concurrently", which was not what they wanted.  Now this
syntax will result in a concurrent build of an index with system-chosen
name; which they can rename afterwards if they want something else.

15 years agoRemove code that attempted to rename index columns to keep them in sync with
Tom Lane [Wed, 23 Dec 2009 16:43:43 +0000 (16:43 +0000)]
Remove code that attempted to rename index columns to keep them in sync with
their underlying table columns.  That code was not bright enough to cope with
collision situations (ie, new name conflicts with some other column of the
index).  Since there is no functional reason to do this at all, trying to
upgrade the logic to be bulletproof doesn't seem worth the trouble.

This change means that both the index name and the column names of an index
are set when it's created, and won't be automatically changed when the
underlying table columns are renamed.  Neatnik DBAs are still free to rename
them manually, of course.

15 years agoAdd basic build support for Visual Studio 2008, without resorting to
Magnus Hagander [Wed, 23 Dec 2009 13:27:04 +0000 (13:27 +0000)]
Add basic build support for Visual Studio 2008, without resorting to
generating the build files for 2005 and then converting them.

15 years agoAlways pass catalog id to the options validator function specified in
Heikki Linnakangas [Wed, 23 Dec 2009 12:23:59 +0000 (12:23 +0000)]
Always pass catalog id to the options validator function specified in
CREATE FOREIGN DATA WRAPPER. Arguably it wasn't a bug because the
documentation said that it's passed the catalog ID or zero, but surely
we should provide it when it's known. And there isn't currently any
scenario where it's not known, and I can't imagine having one in the
future either, so better remove the "or zero" escape hatch and always
pass a valid catalog ID. Backpatch to 8.4.

Martin Pihlak

15 years agoRename pg_dump.c TypeInfo variable tinfo to tyinfo, for clarity.
Bruce Momjian [Wed, 23 Dec 2009 04:10:50 +0000 (04:10 +0000)]
Rename pg_dump.c TypeInfo variable tinfo to tyinfo, for clarity.

15 years agoAdjust naming of indexes and their columns per recent discussion.
Tom Lane [Wed, 23 Dec 2009 02:35:25 +0000 (02:35 +0000)]
Adjust naming of indexes and their columns per recent discussion.

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.  (That happens for regular columns too, thus fixing the old problem
that CREATE INDEX fooi ON foo (f1, f1) fails.  Before exclusion indexes
there was no real reason to do such a thing, but now maybe there is.)

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.
(Of course, this will be truncated as needed to fit in NAMEDATALEN.  Also,
pkey indexes retain the historical behavior of not naming specific columns
at all.)

An example of the results:

regression=# create table foo (f1 int, f2 text,
regression(# exclude (f1 with =, lower(f2) with =));
NOTICE:  CREATE TABLE / EXCLUDE will create implicit index "foo_f1_lower_exclusion" for table "foo"
CREATE TABLE
regression=# \d foo_f1_lower_exclusion
Index "public.foo_f1_lower_exclusion"
 Column |  Type   | Definition
--------+---------+------------
 f1     | integer | f1
 lower  | text    | lower(f2)
btree, for table "public.foo"

15 years agoDisallow comments on columns of relation types other than tables, views,
Tom Lane [Tue, 22 Dec 2009 23:54:17 +0000 (23:54 +0000)]
Disallow comments on columns of relation types other than tables, views,
and composite types, which are the only relkinds for which pg_dump support
exists for dumping column comments.  There is no obvious usefulness for
comments on columns of sequences or toast tables; and while comments on
index columns might have some value, it's not worth the risk of compatibility
problems due to possible changes in the algorithm for assigning names to
index columns.  Per discussion.

In consequence, remove now-dead code for copying such comments in CREATE TABLE
LIKE.

15 years agoIn CREATE SEQUENCE dump, put MINVALUE before MAXVALUE so it reads better.
Peter Eisentraut [Tue, 22 Dec 2009 23:27:41 +0000 (23:27 +0000)]
In CREATE SEQUENCE dump, put MINVALUE before MAXVALUE so it reads better.

15 years agoMore cleanups for the recent large object permissions patch.
Robert Haas [Mon, 21 Dec 2009 01:34:11 +0000 (01:34 +0000)]
More cleanups for the recent large object permissions patch.

Rewrite or adjust various comments for clarity.  Remove one bogus comment that
doesn't reflect what the code actually does.  Improve the description of the
lo_compat_privileges option.

15 years agoThere is no good reason for the CREATE TABLE LIKE INCLUDING COMMENTS code to
Tom Lane [Sun, 20 Dec 2009 18:28:14 +0000 (18:28 +0000)]
There is no good reason for the CREATE TABLE LIKE INCLUDING COMMENTS code to
have hard-wired knowledge of the rules for naming index columns.  It can
just look at the actual names in the source index, instead.  Do some minor
formatting cleanup too.

15 years agoFix two small typos in Hot Standby docs.
Robert Haas [Sun, 20 Dec 2009 03:49:58 +0000 (03:49 +0000)]
Fix two small typos in Hot Standby docs.

John Naylor

15 years agoAdd documentation why reassigning PL/Python function parameters in the
Peter Eisentraut [Sat, 19 Dec 2009 22:23:21 +0000 (22:23 +0000)]
Add documentation why reassigning PL/Python function parameters in the
function body can have undesirable outcomes. (bug #5232)

15 years agoAdd hot standby to release notes
Peter Eisentraut [Sat, 19 Dec 2009 20:33:12 +0000 (20:33 +0000)]
Add hot standby to release notes

15 years agoTranslation updates
Peter Eisentraut [Sat, 19 Dec 2009 20:23:26 +0000 (20:23 +0000)]
Translation updates

15 years agoConvert tabs to spaces in SGML.
Bruce Momjian [Sat, 19 Dec 2009 17:49:50 +0000 (17:49 +0000)]
Convert tabs to spaces in SGML.

15 years agoSigh, I managed to break the no-links-in-plain-text-docs rule too...
Tom Lane [Sat, 19 Dec 2009 05:37:01 +0000 (05:37 +0000)]
Sigh, I managed to break the no-links-in-plain-text-docs rule too...

15 years agoAdd a whitespace to fix the query to dump large objects.
Itagaki Takahiro [Sat, 19 Dec 2009 04:13:30 +0000 (04:13 +0000)]
Add a whitespace to fix the query to dump large objects.

PL/pgSQL-by-default patch broke the code for 8.3 <= server_version < 8.5.

15 years agoBump catversion to reflect the fact that HS patch changed pg_proc
Tom Lane [Sat, 19 Dec 2009 04:08:32 +0000 (04:08 +0000)]
Bump catversion to reflect the fact that HS patch changed pg_proc
contents, and PG_CONTROL_VERSION to reflect the fact that it changed
pg_control contents.  (I see we did at least remember to change
XLOG_PAGE_MAGIC for the WAL contents changes.)

15 years agoAdd missing Id keyword to alter_large_object.sgml.
Itagaki Takahiro [Sat, 19 Dec 2009 03:29:28 +0000 (03:29 +0000)]
Add missing Id keyword to alter_large_object.sgml.

15 years agoplpgsql patch broke the MSVC build, too.
Tom Lane [Sat, 19 Dec 2009 02:44:06 +0000 (02:44 +0000)]
plpgsql patch broke the MSVC build, too.

15 years agoJoin in the fun of editorializing on the alpha release notes.
Tom Lane [Sat, 19 Dec 2009 02:38:54 +0000 (02:38 +0000)]
Join in the fun of editorializing on the alpha release notes.

15 years agoUpdate ecpg regression tests to plpgsql installed by default.
Alvaro Herrera [Sat, 19 Dec 2009 02:38:51 +0000 (02:38 +0000)]
Update ecpg regression tests to plpgsql installed by default.

15 years agoUpdate tutorial on the fact that backslash commands are no longer listed in
Alvaro Herrera [Sat, 19 Dec 2009 02:34:17 +0000 (02:34 +0000)]
Update tutorial on the fact that backslash commands are no longer listed in
psql's startup banner.

15 years agoAdjust some more places in the documentation to match the fact that
Tom Lane [Sat, 19 Dec 2009 01:49:02 +0000 (01:49 +0000)]
Adjust some more places in the documentation to match the fact that
plpgsql is now installed by default.

15 years agoAllow read only connections during recovery, known as Hot Standby.
Simon Riggs [Sat, 19 Dec 2009 01:32:45 +0000 (01:32 +0000)]
Allow read only connections during recovery, known as Hot Standby.

Enabled by recovery_connections = on (default) and forcing archive recovery using a recovery.conf. Recovery processing now emulates the original transactions as they are replayed, providing full locking and MVCC behaviour for read only queries. Recovery must enter consistent state before connections are allowed, so there is a delay, typically short, before connections succeed. Replay of recovering transactions can conflict and in some cases deadlock with queries during recovery; these result in query cancellation after max_standby_delay seconds have expired. Infrastructure changes have minor effects on normal running, though introduce four new types of WAL record.

New test mode "make standbycheck" allows regression tests of static command behaviour on a standby server while in recovery. Typical and extreme dynamic behaviours have been checked via code inspection and manual testing. Few port specific behaviours have been utilised, though primary testing has been on Linux only so far.

This commit is the basic patch. Additional changes will follow in this release to enhance some aspects of behaviour, notably improved handling of conflicts, deadlock detection and query cancellation. Changes to VACUUM FULL are also required.

Simon Riggs, with significant and lengthy review by Heikki Linnakangas, including streamlined redesign of snapshot creation and two-phase commit.

Important contributions from Florian Pflug, Mark Kirkwood, Merlin Moncure, Greg Stark, Gianni Ciolli, Gabriele Bartolini, Hannu Krosing, Robert Haas, Tatsuo Ishii, Hiroyuki Yamada plus support and feedback from many other community members.

15 years agobinary migration: pg_migrator
Bruce Momjian [Sat, 19 Dec 2009 00:47:57 +0000 (00:47 +0000)]
binary migration:  pg_migrator

Add comments about places where system oids have to be preserved for
binary migration.

15 years agoFix a few typos in the latest 8.5alpha3 release notes.
Robert Haas [Sat, 19 Dec 2009 00:05:27 +0000 (00:05 +0000)]
Fix a few typos in the latest 8.5alpha3 release notes.

15 years ago8.5alpha3 release notes up to Fri Dec 18 21:37:38 2009 +0000
Peter Eisentraut [Fri, 18 Dec 2009 22:11:09 +0000 (22:11 +0000)]
8.5alpha3 release notes up to Fri Dec 18 21:37:38 2009 +0000

15 years agoFix link that doesn't work in standalone INSTALL document.
Tom Lane [Fri, 18 Dec 2009 21:37:38 +0000 (21:37 +0000)]
Fix link that doesn't work in standalone INSTALL document.

15 years agoInstall server-side language PL/pgSQL by default.
Bruce Momjian [Fri, 18 Dec 2009 21:28:42 +0000 (21:28 +0000)]
Install server-side language PL/pgSQL by default.

15 years agoForce the TZ environment variable to be set during initdb. This is to
Tom Lane [Fri, 18 Dec 2009 18:45:50 +0000 (18:45 +0000)]
Force the TZ environment variable to be set during initdb.  This is to
short-circuit the rather expensive identify_system_timezone() procedure,
which we have no real need for during initdb since nothing done here depends
on the timezone setting.  Since we launch quite a few standalone backends
during the initdb sequence, this adds up to a significant savings, and seems
worth doing to save developer time even though it will hardly matter to end
users.  Per my report today on pgsql-hackers.

15 years agoImprove documentation for pg_largeobject changes.
Robert Haas [Thu, 17 Dec 2009 14:36:16 +0000 (14:36 +0000)]
Improve documentation for pg_largeobject changes.

Rewrite the documentation in more idiomatic English, and in the process make
it somewhat more succinct.  Move the discussion of specific large object
privileges out of the "server-side functions" section, where it certainly
doesn't belong, and into "implementation features".  That might not be
exactly right either, but it doesn't seem worth creating a new section for
this amount of information. Fix a few spelling and layout problems, too.

15 years agoReverting accidently commited changes.
Michael Meskes [Thu, 17 Dec 2009 07:28:58 +0000 (07:28 +0000)]
Reverting accidently commited changes.

15 years agoDon't unblock SIGQUIT in the SIGQUIT handler
Peter Eisentraut [Wed, 16 Dec 2009 23:05:00 +0000 (23:05 +0000)]
Don't unblock SIGQUIT in the SIGQUIT handler

This was possibly linked to a deadlock-like situation in glibc syslog code
invoked by the ereport call in quickdie().  In any case, a signal handler
should not unblock its own signal unless there is a specific reason to.

15 years agoIf there is no sigdelset(), define it as a macro.
Peter Eisentraut [Wed, 16 Dec 2009 22:55:34 +0000 (22:55 +0000)]
If there is no sigdelset(), define it as a macro.

This removes some duplicate code that recreated the identical workaround
when the newer signal API is missing.

15 years agoAvoid a premature coercion failure in transformSetOperationTree() when
Tom Lane [Wed, 16 Dec 2009 22:24:13 +0000 (22:24 +0000)]
Avoid a premature coercion failure in transformSetOperationTree() when
presented with an UNKNOWN-type Var, which can happen in cases where an
unknown literal appeared in a subquery.  While many such cases will fail
later on anyway in the planner, there are some cases where the planner is
able to flatten the query and replace the Var by the constant before it has
to coerce the union column to the final type.  I had added this check in 8.4
to provide earlier/better error detection, but it causes a regression for
some cases that worked OK before.  Fix by not making the check if the input
node is UNKNOWN type and not a Const or Param.  If it isn't going to work,
it will fail anyway at plan time, with the only real loss being inability to
provide an error cursor.  Per gripe from Britt Piehler.

In passing, rename a couple of variables to remove confusion from an
inner scope masking the same variable names in an outer scope.

15 years agoSeveral fixes for EXPLAIN (FORMAT YAML), plus one for EXPLAIN (FORMAT JSON).
Robert Haas [Wed, 16 Dec 2009 22:16:16 +0000 (22:16 +0000)]
Several fixes for EXPLAIN (FORMAT YAML), plus one for EXPLAIN (FORMAT JSON).

ExplainSeparatePlans() was busted for both JSON and YAML output - the present
code is a holdover from the original version of my machine-readable explain
patch, which didn't have the grouping_stack machinery.  Also, fix an odd
distribution of labor between ExplainBeginGroup() and ExplainYAMLLineStarting()
when marking lists with "- ", with each providing one character.  This broke
the output format for multi-query statements.  Also, fix ExplainDummyGroup()
for the YAML output format.

Along the way, make the YAML format use escape_yaml() in situations where the
JSON format uses escape_json().  Right now, it doesn't matter because all the
values are known not to need escaping, but it seems safer this way.  Finally,
I added some comments to better explain what the YAML output format is doing.

Greg Sabino Mullane reported the issues with multi-query statements.
Analysis and remaining cleanups by me.

15 years agoRemove spurious '22' that clearly shouldn't be there.
Magnus Hagander [Wed, 16 Dec 2009 19:38:54 +0000 (19:38 +0000)]
Remove spurious '22' that clearly shouldn't be there.

David E. Wheeler

15 years agoFixed auto-prepare to not try preparing statements that are not preparable. Bug
Michael Meskes [Wed, 16 Dec 2009 10:15:07 +0000 (10:15 +0000)]
Fixed auto-prepare to not try preparing statements that are not preparable. Bug
found and solved by Boszormenyi Zoltan <zb@cybertec.at>, some small adjustments
by me.

15 years agoPython 3 support in PL/Python
Peter Eisentraut [Tue, 15 Dec 2009 22:59:55 +0000 (22:59 +0000)]
Python 3 support in PL/Python

Behaves more or less unchanged compared to Python 2, but the new language
variant is called plpython3u.  Documentation describing the naming scheme
is included.

15 years agoAvoid unnecessary copying of source string when generating a cloned TParser.
Tom Lane [Tue, 15 Dec 2009 20:37:17 +0000 (20:37 +0000)]
Avoid unnecessary copying of source string when generating a cloned TParser.
For long source strings the copying results in O(N^2) behavior, and the
multiplier can be significant if wide-char conversion is involved.

Andres Freund, reviewed by Kevin Grittner.

15 years agoAdd a hook to let loadable modules get control at ProcessUtility execution,
Tom Lane [Tue, 15 Dec 2009 20:04:49 +0000 (20:04 +0000)]
Add a hook to let loadable modules get control at ProcessUtility execution,
and use it to extend contrib/pg_stat_statements to track utility commands.

Itagaki Takahiro, reviewed by Euler Taveira de Oliveira.

15 years agoSupport ORDER BY within aggregate function calls, at long last providing a
Tom Lane [Tue, 15 Dec 2009 17:57:48 +0000 (17:57 +0000)]
Support ORDER BY within aggregate function calls, at long last 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 for single-argument aggregates.

Possibly release-notable behavioral change: formerly, agg(DISTINCT x)
dropped null values of x unconditionally.  Now, it does so only if the
agg transition function is strict; otherwise nulls are treated as DISTINCT
normally would, ie, you get one copy.

Andrew Gierth, reviewed by Hitoshi Harada

15 years agoFix broken markup.
Tom Lane [Tue, 15 Dec 2009 15:59:57 +0000 (15:59 +0000)]
Fix broken markup.