users/bernd/postgres.git
17 years agoImprove conversion of legacy CREATE CONSTRAINT TRIGGER representation of
Tom Lane [Mon, 5 Nov 2007 19:00:25 +0000 (19:00 +0000)]
Improve conversion of legacy CREATE CONSTRAINT TRIGGER representation of
foreign keys, one more time.  Insist on matching up all three triggers before
we create a constraint; this will avoid creation of duplicate constraints
in scenarios where a broken FK constraint was repaired by re-adding the
constraint without removing the old partial trigger set.  Basically, this will
work nicely in all cases where the FK was actually functioning correctly in
the database that was dumped.  It will fail to restore an FK in just one case
where we theoretically could restore it: where we find the referenced table's
triggers and not the referencing table's trigger.  However, in such a scenario
it's likely that the user doesn't even realize he still has an FK at all
(since the more-likely-to-fail cases aren't enforced), and we'd probably not
accomplish much except to cause the reload to fail because the data doesn't
meet the FK constraint.  Also make the NOTICE logging still more verbose, by
adding detail about which of the triggers were found.  This seems about all
we can do without solving the problem of getting the user's attention at
session end.

17 years agoDocument that configure option only affects contrib:
Bruce Momjian [Mon, 5 Nov 2007 17:43:20 +0000 (17:43 +0000)]
Document that configure option only affects contrib:

 --with-ossp-uuid        use OSSP UUID library when building /contrib/uuid-ossp

17 years agoMinor editorial improvements to txid functions' documentation: put back
Tom Lane [Mon, 5 Nov 2007 17:40:21 +0000 (17:40 +0000)]
Minor editorial improvements to txid functions' documentation: put back
some text that got dropped, improve markup, improve descriptions of
snapshot components.

17 years agoDocument that syncronhous commit can be turned off in a single
Bruce Momjian [Mon, 5 Nov 2007 17:35:38 +0000 (17:35 +0000)]
Document that syncronhous commit can be turned off in a single
multi-statement transaction.

17 years agoProperly pass third argument to open() in fsync test program.
Bruce Momjian [Mon, 5 Nov 2007 17:10:26 +0000 (17:10 +0000)]
Properly pass third argument to open() in fsync test program.

Hiroshi Saito

17 years agoRemove <sect1> of txid functions.
Bruce Momjian [Mon, 5 Nov 2007 16:57:23 +0000 (16:57 +0000)]
Remove <sect1> of txid functions.

17 years agoMove txid snapshot field description table from datatype to functions section.
Bruce Momjian [Mon, 5 Nov 2007 16:45:52 +0000 (16:45 +0000)]
Move txid snapshot field description table from datatype to functions section.

17 years agoFix typos.
Magnus Hagander [Mon, 5 Nov 2007 15:55:53 +0000 (15:55 +0000)]
Fix typos.

Guillaume Lelarge

17 years agoDocument txid functions.
Bruce Momjian [Mon, 5 Nov 2007 14:51:08 +0000 (14:51 +0000)]
Document txid functions.

Marko Kreen

17 years agoAdd a note about another issue that needs to be considered before
Tom Lane [Mon, 5 Nov 2007 14:11:17 +0000 (14:11 +0000)]
Add a note about another issue that needs to be considered before
changing the TOAST size thresholds.

17 years agoRemove deprecation notice and add comment about safely restoring backups.
D'Arcy J.M. Cain [Mon, 5 Nov 2007 12:02:20 +0000 (12:02 +0000)]
Remove deprecation notice and add comment about safely restoring backups.
As per discussion on hackers.

17 years agoUse LOG instead of DEBUG2 for logging invalid cancel requests. (That is,
Neil Conway [Mon, 5 Nov 2007 00:00:34 +0000 (00:00 +0000)]
Use LOG instead of DEBUG2 for logging invalid cancel requests. (That is,
cancel requests with an incorrect key, or with a non-existent PID). Per
recent discussion on -hackers.

17 years agoWorking improvement.
Bruce Momjian [Sun, 4 Nov 2007 21:50:28 +0000 (21:50 +0000)]
Working improvement.

17 years agoAdd link to NFS section from "creating a database cluster.
Bruce Momjian [Sun, 4 Nov 2007 21:48:03 +0000 (21:48 +0000)]
Add link to NFS section from "creating a database cluster.

17 years agoDocument possible problems with NFS tablespaces.
Bruce Momjian [Sun, 4 Nov 2007 21:40:02 +0000 (21:40 +0000)]
Document possible problems with NFS tablespaces.

17 years agoMinor improvements to code for converting legacy CREATE CONSTRAINT TRIGGER
Tom Lane [Sun, 4 Nov 2007 21:25:55 +0000 (21:25 +0000)]
Minor improvements to code for converting legacy CREATE CONSTRAINT TRIGGER
commands into proper foreign-key constraints.  Believe the constraint name
given in the trigger arguments in preference to the trigger name --- to judge
from Olivier Prenant's example, pg_dump must at some time have used the
autogenerated trigger name there, though AFAICT no current release branch tip
does.  Improve the emitted NOTICEs to provide more detail (PK table's name and
column names).  Handle the case where pg_dump forgot to provide the FROM table
(a bug that never did get fixed in 7.0.x apparently).  This commit doesn't
do anything about the question of what to do with incomplete trigger groups.

17 years agoProperly indent tablespace SGML section.
Bruce Momjian [Sun, 4 Nov 2007 19:43:33 +0000 (19:43 +0000)]
Properly indent tablespace SGML section.

17 years agoMention "replication" in the title of the high availability and load
Bruce Momjian [Sun, 4 Nov 2007 19:23:24 +0000 (19:23 +0000)]
Mention "replication" in the title of the high availability and load
balancing chapter because some people were looking for 'replication' and
didn't realize that chapter addressed it.

17 years agoUpdate wording for xsl configure option.
Bruce Momjian [Sun, 4 Nov 2007 18:53:39 +0000 (18:53 +0000)]
Update wording for xsl configure option.

17 years agoDocument that configure --with-libxslt controls just /contrib/xml2.
Bruce Momjian [Sun, 4 Nov 2007 18:10:42 +0000 (18:10 +0000)]
Document that configure --with-libxslt controls just /contrib/xml2.

Nikolay Samokhvalov

17 years agoPrevent continuing disk-space bloat when profiling (with PROFILE_PID_DIR
Tom Lane [Sun, 4 Nov 2007 17:55:15 +0000 (17:55 +0000)]
Prevent continuing disk-space bloat when profiling (with PROFILE_PID_DIR
enabled) and autovacuum is on.  Since there will be a steady stream of autovac
worker processes exiting and dropping gmon.out files, allowing them to make
separate subdirectories results in serious bloat; and it seems unlikely that
anyone will care about those profiles anyway.  Limit the damage by forcing all
autovac workers to dump in one subdirectory, PGDATA/gprof/avworker/.

Per report from J\9arg Beyer and subsequent discussion.

17 years agoTeach CREATE CONSTRAINT TRIGGER to convert old-style foreign key
Tom Lane [Sun, 4 Nov 2007 01:16:19 +0000 (01:16 +0000)]
Teach CREATE CONSTRAINT TRIGGER to convert old-style foreign key
trigger definitions into regular foreign key constraints.  This seems
necessary given that some people evidently never did get around to
running adddepend on their schemas, and without some sort of hack the
old definitions will no longer work.  Per report from Olivier Prenant
and subsequent investigation.

17 years agoEnsure that EquivalenceClasses generated from ORDER BY keys contain proper
Tom Lane [Fri, 2 Nov 2007 18:54:15 +0000 (18:54 +0000)]
Ensure that EquivalenceClasses generated from ORDER BY keys contain proper
RelabelType nodes when the sort key is binary-compatible with the sort
operator rather than having exactly its input type.  We did this correctly
for index columns but not sort keys, leading to failure to notice that
a varchar index matches an ORDER BY request.  This requires a bit more work
in make_sort_from_pathkeys, but not anyplace else that I can find.
Per bug report and subsequent discussion.

17 years agoMention that internal hash functions changed in 8.3 release notes.
Bruce Momjian [Thu, 1 Nov 2007 22:38:36 +0000 (22:38 +0000)]
Mention that internal hash functions changed in 8.3 release notes.

17 years agoSome corrections/improvements to new acronym list.
Tom Lane [Thu, 1 Nov 2007 20:27:33 +0000 (20:27 +0000)]
Some corrections/improvements to new acronym list.

17 years agoUpdate discussion of shared memory sizing for 8.3: adjust multipliers,
Tom Lane [Thu, 1 Nov 2007 19:06:01 +0000 (19:06 +0000)]
Update discussion of shared memory sizing for 8.3: adjust multipliers,
mention autovacuum_max_workers.  Minor copy-editing too.

17 years agoUpdate Czech FAQ.
Bruce Momjian [Thu, 1 Nov 2007 17:28:03 +0000 (17:28 +0000)]
Update Czech FAQ.

Pavel Stehule

17 years agoAcronym spelling fix.
Bruce Momjian [Thu, 1 Nov 2007 17:16:36 +0000 (17:16 +0000)]
Acronym spelling fix.

17 years agoAdd documentation mention that FSM == Free Space Map, so the config
Bruce Momjian [Thu, 1 Nov 2007 17:06:30 +0000 (17:06 +0000)]
Add documentation mention that FSM == Free Space Map, so the config
parameter name makes more sense.

17 years agoAdd acronym section to our documentation.
Bruce Momjian [Thu, 1 Nov 2007 17:00:46 +0000 (17:00 +0000)]
Add acronym section to our documentation.

17 years agoAdd:
Bruce Momjian [Wed, 31 Oct 2007 20:12:44 +0000 (20:12 +0000)]
Add:

> * Prevent long-lived temporary tables from causing frozen-Xid advancement
>    starvation

17 years agoMore precise error message
Peter Eisentraut [Wed, 31 Oct 2007 10:55:25 +0000 (10:55 +0000)]
More precise error message

18 years agoremoved from CVS
Marc G. Fournier [Tue, 30 Oct 2007 23:38:23 +0000 (23:38 +0000)]
removed from CVS

18 years agoAdd note on PostgreSQL vs. Postgres.
Peter Eisentraut [Tue, 30 Oct 2007 23:06:06 +0000 (23:06 +0000)]
Add note on PostgreSQL vs. Postgres.

18 years agoUpdate some obsolete stuff in the GRANT and REVOKE reference pages:
Tom Lane [Tue, 30 Oct 2007 19:43:30 +0000 (19:43 +0000)]
Update some obsolete stuff in the GRANT and REVOKE reference pages:
simplify the syntax examples by unifying user and group cases, and fix
no-longer-correct example of psql \z output.  Per Erwin Brandstetter.

18 years agoAdd a note pointing out that some other databases make GREATEST and
Tom Lane [Tue, 30 Oct 2007 19:06:56 +0000 (19:06 +0000)]
Add a note pointing out that some other databases make GREATEST and
LEAST handle NULL arguments differently than we do.  Per a discussion
on 30-Jun that somehow didn't get done.

18 years agosimple script to pull together a very small (<500k) tar file that builds
Marc G. Fournier [Tue, 30 Oct 2007 02:34:48 +0000 (02:34 +0000)]
simple script to pull together a very small (<500k) tar file that builds
*just* libpq ... its not perfect, as it pulls in more files then is
necessarily required to build, but as it is, it requires one simple patch
to configure.in in order to work ...

Tested on FreeBSD ... patch for configure.in hasn't been applied, but
putting the script in place so that it doesn't get lost ...

18 years agoIn the previous commit message, I forgot to credit Simon Riggs who provided
Alvaro Herrera [Mon, 29 Oct 2007 22:17:41 +0000 (22:17 +0000)]
In the previous commit message, I forgot to credit Simon Riggs who provided
the patch, which I modified only slightly before applying.

18 years agoMention the index name in 'could not create unique index' errors,
Tom Lane [Mon, 29 Oct 2007 21:31:28 +0000 (21:31 +0000)]
Mention the index name in 'could not create unique index' errors,
per suggestion from Rene Gollent.

18 years agoRemove the hack in the grammar that "optimized away" DEFAULT NULL clauses.
Tom Lane [Mon, 29 Oct 2007 19:40:40 +0000 (19:40 +0000)]
Remove the hack in the grammar that "optimized away" DEFAULT NULL clauses.
Instead put in a test to drop a NULL default at the last moment before
storing the catalog entry.  This changes the behavior in a couple of ways:
* Specifying DEFAULT NULL when creating an inheritance child table will
  successfully suppress inheritance of any default expression from the
  parent's column, where formerly it failed to do so.
* Specifying DEFAULT NULL for a column of a domain type will correctly
  override any default belonging to the domain; likewise for a sub-domain.
The latter change happens because by the time the clause is checked,
it won't be a simple null Const but a CoerceToDomain expression.

Personally I think this should be back-patched, but there doesn't seem to
be consensus for that on pgsql-hackers, so refraining.

18 years ago- Add check of already changed page while replay WAL. This touches only
Teodor Sigaev [Mon, 29 Oct 2007 19:27:21 +0000 (19:27 +0000)]
- Add check of already changed page while replay WAL. This touches only
ginRedoInsert(), because other ginRedo* functions rewrite whole page or
make changes which could be applied several times without consistent's loss

- Remove check of identifying of corresponding split record:
it's possible that replaying of WAL starts after actual page split, but before
removing of that split from incomplete splits list. In this case, that check
cause FATAL error.

Per stress test which reproduces bug reported by Craig McElroy
<craig.mcelroy@contegix.com>

18 years agoDocumentation wording fixes.
Bruce Momjian [Mon, 29 Oct 2007 17:29:59 +0000 (17:29 +0000)]
Documentation wording fixes.

Guillaume Lelarge

18 years agoUpdate Russian FAQ.
Bruce Momjian [Mon, 29 Oct 2007 17:27:10 +0000 (17:27 +0000)]
Update Russian FAQ.

corochoone@gmail.com

18 years agoClarify restart is of the "database" server, in FAQ.
Bruce Momjian [Mon, 29 Oct 2007 17:22:20 +0000 (17:22 +0000)]
Clarify restart is of the "database" server, in FAQ.

18 years agoMake variable static, per Tom.
Magnus Hagander [Mon, 29 Oct 2007 14:04:42 +0000 (14:04 +0000)]
Make variable static, per Tom.

18 years agoFix coredump during replay WAL after crash. Change entrySplitPage() to prevent
Teodor Sigaev [Mon, 29 Oct 2007 13:49:51 +0000 (13:49 +0000)]
Fix coredump during replay WAL after crash. Change entrySplitPage() to prevent
usage of any information from system catalog, because it could be called during
replay of WAL.

Per bug report from Craig McElroy <craig.mcelroy@contegix.com>. Patch doesn't
change on-disk storage.

18 years agoAdd compat file for dynamically loading the functions that MinGW is missing
Magnus Hagander [Mon, 29 Oct 2007 12:35:41 +0000 (12:35 +0000)]
Add compat file for dynamically loading the functions that MinGW is missing
the imports for. Add RegisterWaitForSingleObject() to the list of such
functions, which should take care of the current buildfarm breakage.

18 years agoNew versions of mingw have gettimeofday(), so add an autoconf test
Magnus Hagander [Mon, 29 Oct 2007 11:25:42 +0000 (11:25 +0000)]
New versions of mingw have gettimeofday(), so add an autoconf test
for this.

18 years agoRemove claim that ts_headline knows how to generate multiple ellipsis-separated
Tom Lane [Mon, 29 Oct 2007 01:55:11 +0000 (01:55 +0000)]
Remove claim that ts_headline knows how to generate multiple ellipsis-separated
excerpts of a document.  That's clearly desirable, but the functionality
is not there yet.

18 years agoOoops, fat-fingered last commit message. Should have
Tom Lane [Sun, 28 Oct 2007 22:33:25 +0000 (22:33 +0000)]
Ooops, fat-fingered last commit message.  Should have
mentioned updating FAQ_IRIX for information about buggy MIPSPro
compiler version, now confirmed by Herve Boulouis.

18 years agoFAQ_IRIX
Tom Lane [Sun, 28 Oct 2007 22:30:21 +0000 (22:30 +0000)]
FAQ_IRIX

18 years agoMake pg_dump and friends consistently report both the filename and the
Tom Lane [Sun, 28 Oct 2007 21:55:52 +0000 (21:55 +0000)]
Make pg_dump and friends consistently report both the filename and the
errno string when complaining of fopen failures.  Per gripe from Bob
Pawley, it's not always instantly obvious to the user which name we
tried to open.

18 years agoFix a couple of issues with pg_dump's handling of inheritance child tables
Tom Lane [Sun, 28 Oct 2007 19:08:25 +0000 (19:08 +0000)]
Fix a couple of issues with pg_dump's handling of inheritance child tables
that have default expressions different from their parent.  First, if the
parent table's default expression has to be split out as a separate
ALTER TABLE command, we need a dependency constraint to ensure that the
child's command is given second.  This is because the ALTER TABLE on the
parent will propagate to the child.  (We can't prevent that by using ONLY on
the parent's command, since it's possible that other children exist that
should receive the inherited default.)  Second, if the child has a NULL
default where the parent does not, we have to explicitly say DEFAULT NULL on
the child in order for this state to be preserved after reload.  (The latter
actually doesn't work right because of a backend bug, but that is a separate
issue.)

Backpatch as far as 8.0.  7.x pg_dump has enough issues with altered tables
(due to lack of dependency analysis) that trying to fix this one doesn't seem
very productive.

18 years agoChange text search parsing rules for hyphenated words so that digit strings
Tom Lane [Sat, 27 Oct 2007 19:03:45 +0000 (19:03 +0000)]
Change text search parsing rules for hyphenated words so that digit strings
containing decimal points aren't considered part of a hyphenated word.
Sync the hyphenated-word lookahead states with the subsequent part-by-part
reparsing states so that we don't get different answers about how much text
is part of the hyphenated word.  Per my gripe of a few days ago.

18 years agoAdd some rudimentary tracing code to the default text search parser, to help
Tom Lane [Sat, 27 Oct 2007 17:53:15 +0000 (17:53 +0000)]
Add some rudimentary tracing code to the default text search parser, to help
in debugging its state-machine rules.  Const-ify all the constant tables.
Minor other code cleanup, including using "token" rather than "lexeme" to
describe the output strings.

18 years agoRename default text search parser's "uri" token type to "url_path",
Tom Lane [Sat, 27 Oct 2007 16:01:09 +0000 (16:01 +0000)]
Rename default text search parser's "uri" token type to "url_path",
per recommendation from Alvaro.  This doesn't force initdb since the
numeric token type in the catalogs doesn't change; but note that
the expected regression test output changed.

18 years agoAvoid considering both sort directions as equally useful for merging.
Tom Lane [Sat, 27 Oct 2007 05:45:43 +0000 (05:45 +0000)]
Avoid considering both sort directions as equally useful for merging.
This doubles the planning workload for mergejoins while not actually
accomplishing much.  The only useful case is where one of the directions
matches the query's ORDER BY request; therefore, put a thumb on the scales
in that direction, and otherwise arbitrarily consider only the ASC direction.
(This is a lot easier now than it would've been before 8.3, since we have
more semantic knowledge embedded in PathKeys now.)

18 years agoStamp 8.3beta2.
Tom Lane [Sat, 27 Oct 2007 00:22:42 +0000 (00:22 +0000)]
Stamp 8.3beta2.

18 years agoMinor wording improvements per suggestion from Jeff Davis. Also tweak
Tom Lane [Sat, 27 Oct 2007 00:19:45 +0000 (00:19 +0000)]
Minor wording improvements per suggestion from Jeff Davis.  Also tweak
hyphenated-word parser examples per earlier discussion with Alvaro.

18 years agoTranslation updates
Peter Eisentraut [Sat, 27 Oct 2007 00:13:43 +0000 (00:13 +0000)]
Translation updates

18 years agoChange win32 child-death tracking code to use a threadpool to wait for
Magnus Hagander [Fri, 26 Oct 2007 21:50:10 +0000 (21:50 +0000)]
Change win32 child-death tracking code to use a threadpool to wait for
childprocess deaths instead of using one thread per child. This drastastically
reduces the address space usage and should allow for more backends running.

Also change the win32_waitpid functionality to use an IO Completion Port for
queueing child death notices instead of using a fixed-size array.

18 years agoAllow an autovacuum worker to be interrupted automatically when it is found
Alvaro Herrera [Fri, 26 Oct 2007 20:45:10 +0000 (20:45 +0000)]
Allow an autovacuum worker to be interrupted automatically when it is found
to be locking another process (except when it's working to prevent Xid
wraparound problems).

18 years agoRemove second-in-paragraph usage of "Postgres" in FAQ_DEV.
Bruce Momjian [Fri, 26 Oct 2007 19:08:57 +0000 (19:08 +0000)]
Remove second-in-paragraph usage of "Postgres" in FAQ_DEV.

18 years agoRemove use of "Postgres" aliases in the FAQ in second-in-paragraph
Bruce Momjian [Fri, 26 Oct 2007 19:04:37 +0000 (19:04 +0000)]
Remove use of "Postgres" aliases in the FAQ in second-in-paragraph
cases.

18 years agoChange have_join_order_restriction() so that we do not force a clauseless join
Tom Lane [Fri, 26 Oct 2007 18:10:58 +0000 (18:10 +0000)]
Change have_join_order_restriction() so that we do not force a clauseless join
if either of the input relations can legally be joined to any other rels using
join clauses.  This avoids uselessly (and expensively) considering a lot of
really stupid join paths when there is a join restriction with a large
footprint, that is, lots of relations inside its LHS or RHS.  My patch of
15-Feb-2007 had been causing the code to consider joining *every* combination
of rels inside such a group, which is exponentially bad :-(.  With this
behavior, clauseless bushy joins will be done if necessary, but they'll be
put off as long as possible.  Per report from Jakub Ouhrabka.

Backpatch to 8.2.  We might someday want to backpatch to 8.1 as well, but 8.1
does not have the problem for OUTER JOIN nests, only for IN-clauses, so it's
not clear anyone's very likely to hit it in practice; and the current patch
doesn't apply cleanly to 8.1.

18 years agoAvoid having backend-only code compiled into ecpg. Per Zdenek Kotala
Tom Lane [Fri, 26 Oct 2007 14:17:53 +0000 (14:17 +0000)]
Avoid having backend-only code compiled into ecpg.  Per Zdenek Kotala

18 years agoAvoid including any backend-only stuff in the zic utility program.
Tom Lane [Fri, 26 Oct 2007 13:30:10 +0000 (13:30 +0000)]
Avoid including any backend-only stuff in the zic utility program.
Per gripe from Zdenek Kotala, though not exactly his patch.

18 years agoSet Japanese FAQ character code to UTF-8.
Bruce Momjian [Fri, 26 Oct 2007 03:59:22 +0000 (03:59 +0000)]
Set Japanese FAQ character code to UTF-8.

Jun Kuwamura

18 years agoAdd plpgsql doc example of RETURN NEXT.
Bruce Momjian [Fri, 26 Oct 2007 01:11:09 +0000 (01:11 +0000)]
Add plpgsql doc example of RETURN NEXT.

Ulrich Kroener

18 years agoMake initdb's selection of default text search configuration depend
Tom Lane [Thu, 25 Oct 2007 20:22:53 +0000 (20:22 +0000)]
Make initdb's selection of default text search configuration depend
only on the 'language' part of the locale name, ignoring the country code.
We may need to be smarter later when there are more built-in configurations,
but for now this is good enough and avoids having to bloat the table.

18 years agoFix memory management for new variables -- they must actually survive
Alvaro Herrera [Thu, 25 Oct 2007 19:13:37 +0000 (19:13 +0000)]
Fix memory management for new variables -- they must actually survive
transaction end, in case we decide to do a vacuum analyze (which is done in two
xacts).

18 years agoFix ALTER SEQUENCE so that it does not affect the value of currval() for
Tom Lane [Thu, 25 Oct 2007 18:54:03 +0000 (18:54 +0000)]
Fix ALTER SEQUENCE so that it does not affect the value of currval() for
the sequence.  Also, make setval() with is_called = false not affect the
currval state, either.  Per report from Kris Jurka that an implicit
ALTER SEQUENCE OWNED BY unexpectedly caused currval() to become valid.
Since this isn't 100% backwards compatible, it will go into HEAD only;
I'll put a more limited patch into 8.2.

18 years agoExtract catalog info for error reporting before an error actually happens.
Alvaro Herrera [Thu, 25 Oct 2007 14:45:55 +0000 (14:45 +0000)]
Extract catalog info for error reporting before an error actually happens.
Also, remove redundant reset of for-wraparound PGPROC flag.

Thanks to Tom Lane for noticing both bogosities.

18 years agoTweak new error messages to match the actual syntax of DECLARE CURSOR.
Tom Lane [Thu, 25 Oct 2007 13:48:57 +0000 (13:48 +0000)]
Tweak new error messages to match the actual syntax of DECLARE CURSOR.
(Last night I copied-and-pasted from the WITH HOLD case, but that's
wrong because of the bizarrely irregular syntax specified by the standard.)

18 years agoUse more real-world examples in the text search parser documentation.
Alvaro Herrera [Thu, 25 Oct 2007 13:06:35 +0000 (13:06 +0000)]
Use more real-world examples in the text search parser documentation.

18 years agoAdd new encoding aliases for Solaris, per Zdenek Kotala.
Alvaro Herrera [Thu, 25 Oct 2007 12:29:17 +0000 (12:29 +0000)]
Add new encoding aliases for Solaris, per Zdenek Kotala.

18 years agoUpdate release notes to current CVS.
Bruce Momjian [Thu, 25 Oct 2007 02:50:26 +0000 (02:50 +0000)]
Update release notes to current CVS.

18 years agoDisallow scrolling of FOR UPDATE/FOR SHARE cursors, so as to avoid problems
Tom Lane [Wed, 24 Oct 2007 23:27:08 +0000 (23:27 +0000)]
Disallow scrolling of FOR UPDATE/FOR SHARE cursors, so as to avoid problems
in corner cases such as re-fetching a just-deleted row.  We may be able to
relax this someday, but let's find out how many people really care before
we invest a lot of work in it.  Per report from Heikki and subsequent
discussion.

While in the neighborhood, make the combination of INSENSITIVE and FOR UPDATE
throw an error, since they are semantically incompatible.  (Up to now we've
accepted but just ignored the INSENSITIVE option of DECLARE CURSOR.)

18 years agoRemove obsolete statement that you can't update through a cursor.
Tom Lane [Wed, 24 Oct 2007 22:55:52 +0000 (22:55 +0000)]
Remove obsolete statement that you can't update through a cursor.

18 years agoRearrange vacuum-related bits in PGPROC as a bitmask, to better support
Alvaro Herrera [Wed, 24 Oct 2007 20:55:36 +0000 (20:55 +0000)]
Rearrange vacuum-related bits in PGPROC as a bitmask, to better support
having several of them.  Add two more flags: whether the process is
executing an ANALYZE, and whether a vacuum is for Xid wraparound (which
is obviously only set by autovacuum).

Sneakily move the worker's recently-acquired PostAuthDelay to a more useful
place.

18 years agoFix an error in make_outerjoininfo introduced by my patch of 30-Aug: the code
Tom Lane [Wed, 24 Oct 2007 20:54:33 +0000 (20:54 +0000)]
Fix an error in make_outerjoininfo introduced by my patch of 30-Aug: the code
neglected to test whether an outer join's join-condition actually refers to
the lower outer join it is looking at.  (The comment correctly described what
was supposed to happen, but the code didn't do it...)  This often resulted in
adding an unnecessary constraint on the join order of the two outer joins,
which was bad enough.  However, it also seems to expose a performance
problem in an older patch (from 15-Feb): once we've decided that there is a
join ordering constraint, we will start trying clauseless joins between every
combination of rels within the constraint, which pointlessly eats up lots of
time and space if there are numerous rels below the outer join.  That probably
needs to be revisited :-(.  Per gripe from Jakub Ouhrabka.

18 years agoDanish_Danmark -> Danish_Denmark
Alvaro Herrera [Wed, 24 Oct 2007 20:11:00 +0000 (20:11 +0000)]
Danish_Danmark -> Danish_Denmark

18 years agoMinor changes to autovacuum worker: change error handling so that it continues
Alvaro Herrera [Wed, 24 Oct 2007 19:08:25 +0000 (19:08 +0000)]
Minor changes to autovacuum worker: change error handling so that it continues
with the next table on schedule instead of exiting, in all cases instead of
just on query cancel.

Add a errcontext() line indicating the activity of the worker to the error
message when it is cancelled.

Change the WorkerInfo struct to contain a pointer to the worker's PGPROC
instead of just the PID.

Add forgotten post-auth delays, per Simon Riggs.  Also to autovac launcher.

18 years agoFix UPDATE/DELETE WHERE CURRENT OF to support repeated update and update-
Tom Lane [Wed, 24 Oct 2007 18:37:09 +0000 (18:37 +0000)]
Fix UPDATE/DELETE WHERE CURRENT OF to support repeated update and update-
then-delete on the current cursor row.  The basic fix is that nodeTidscan.c
has to apply heap_get_latest_tid() to the current-scan-TID obtained from the
cursor query; this ensures we get the latest row version to work with.
However, since that only works if the query plan is a TID scan, we also have
to hack the planner to make sure only that type of plan will be selected.
(Formerly, the planner might decide to apply a seqscan if the table is very
small.  This change is probably a Good Thing anyway, since it's hard to see
how a seqscan could really win.)  That means the execQual.c code to support
CurrentOfExpr as a regular expression type is dead code, so replace it with
just an elog().  Also, add regression tests covering these cases.  Note
that the added tests expose the fact that re-fetching an updated row
misbehaves if the cursor used FOR UPDATE.  That's an independent bug that
should be fixed later.  Per report from Dharmendra Goyal.

18 years agoKeep heap_page_prune from marking the buffer dirty when it didn't
Tom Lane [Wed, 24 Oct 2007 13:05:57 +0000 (13:05 +0000)]
Keep heap_page_prune from marking the buffer dirty when it didn't
really change anything.  Per report from Itagaki Takahiro.  Fix by
Pavan Deolasee.

18 years agoSet read_only = TRUE while evaluating input queries for ts_rewrite()
Tom Lane [Wed, 24 Oct 2007 03:30:03 +0000 (03:30 +0000)]
Set read_only = TRUE while evaluating input queries for ts_rewrite()
and ts_stat(), per my recent suggestion.  Also add a possibly-not-needed-
but-can't-hurt check for NULL SPI_tuptable, before we try to dereference
same.

18 years agoRemove the aggregate form of ts_rewrite(), since it doesn't work as desired
Tom Lane [Wed, 24 Oct 2007 02:24:49 +0000 (02:24 +0000)]
Remove the aggregate form of ts_rewrite(), since it doesn't work as desired
if there are zero rows to aggregate over, and the API seems both conceptually
and notationally ugly anyway.  We should look for something that improves
on the tsquery-and-text-SELECT version (which is also pretty ugly but at
least it works...), but it seems that will take query infrastructure that
doesn't exist today.  (Hm, I wonder if there's anything in or near SQL2003
window functions that would help?)  Per discussion.

18 years agoMake configure probe for the location of the <uuid.h> header file.
Tom Lane [Tue, 23 Oct 2007 21:38:16 +0000 (21:38 +0000)]
Make configure probe for the location of the <uuid.h> header file.
Needed to accommodate different layout on some platforms (Debian for
one).  Heikki Linnakangas

18 years agoRename and slightly redefine the default text search parser's "word"
Tom Lane [Tue, 23 Oct 2007 20:46:12 +0000 (20:46 +0000)]
Rename and slightly redefine the default text search parser's "word"
categories, as per discussion.  asciiword (formerly lword) is still
ASCII-letters-only, and numword (formerly word) is still the most general
mixed-alpha-and-digits case.  But word (formerly nlword) is now
any-group-of-letters-with-at-least-one-non-ASCII, rather than all-non-ASCII as
before.  This is no worse than before for parsing mixed Russian/English text,
which seems to have been the design center for the original coding; and it
should simplify matters for parsing most European languages.  In particular
it will not be necessary for any language to accept strings containing digits
as being regular "words".  The hyphenated-word categories are adjusted
similarly.

18 years agoUse snprintf instead of wsprintf, and use getenv("APPDATA") instead of
Magnus Hagander [Tue, 23 Oct 2007 17:58:01 +0000 (17:58 +0000)]
Use snprintf instead of wsprintf, and use getenv("APPDATA") instead of
SHGetFolderPath.

This removes the direct dependency on shell32.dll and user32.dll, which
eats a lot of "desktop heap" for each backend that's started. The
desktop heap is a very limited resource, causing backends to no
longer start once it's been exhausted.

We still have indirect depdendencies on user32.dll through third party
libraries, but those can't easily be removed.

Dave Page

18 years agoFix two-argument form of ts_rewrite() so it actually works for cases where
Tom Lane [Tue, 23 Oct 2007 01:44:40 +0000 (01:44 +0000)]
Fix two-argument form of ts_rewrite() so it actually works for cases where
a later rewrite rule should change a subtree modified by an earlier one.
Per my gripe of a few days ago.

18 years agoFix several bugs in tsvectorin, including crash due to uninitialized field and
Tom Lane [Tue, 23 Oct 2007 00:51:23 +0000 (00:51 +0000)]
Fix several bugs in tsvectorin, including crash due to uninitialized field and
miscomputation of required palloc size.  The crash could only occur if the
input contained lexemes both with and without positions, which is probably not
common in practice.  The miscomputation would definitely result in wasted
space.  Also fix some inconsistent coding around alignment of strings and
positions in a tsvector value; these errors could also lead to crashes given
mixed with/without position data and a machine that's picky about alignment.
And be more careful about checking for overflow of string offsets.

Patch is only against HEAD --- I have not looked to see if same bugs are
in back-branch contrib/tsearch2 code.

18 years agoClarify example of planner cost computation, per a suggestion from
Tom Lane [Mon, 22 Oct 2007 21:34:33 +0000 (21:34 +0000)]
Clarify example of planner cost computation, per a suggestion from
James Shaw.  Also update a couple of examples to reflect 8.3's improved
plan-printing code.

18 years agoAdjust ts_debug's output as per my proposal of yesterday: show the
Tom Lane [Mon, 22 Oct 2007 20:13:37 +0000 (20:13 +0000)]
Adjust ts_debug's output as per my proposal of yesterday: show the
active dictionary and its output lexemes as separate columns, instead
of smashing them into one text column, and lowercase the column names.
Also, define the output rowtype using OUT parameters instead of a
composite type, to be consistent with the other built-in functions.

18 years agoBe careful to get share lock on each page before computing its free space.
Tom Lane [Mon, 22 Oct 2007 17:29:35 +0000 (17:29 +0000)]
Be careful to get share lock on each page before computing its free space.
ITAGAKI Takahiro

18 years agoRemove an Assert that's been obsoleted by recent changes in the parsetree
Tom Lane [Mon, 22 Oct 2007 17:04:35 +0000 (17:04 +0000)]
Remove an Assert that's been obsoleted by recent changes in the parsetree
representation of DECLARE CURSOR.  Report and fix by Heikki.

18 years agoIncrease FD_SETSIZE on Win32 to allow for more than 54 clients.
Magnus Hagander [Mon, 22 Oct 2007 10:40:47 +0000 (10:40 +0000)]
Increase FD_SETSIZE on Win32 to allow for more than 54 clients.

Per Greg Stark & Dave Page

18 years agoCreate a quick-and-dirty list of known migration issues for pre-8.3
Tom Lane [Mon, 22 Oct 2007 03:37:04 +0000 (03:37 +0000)]
Create a quick-and-dirty list of known migration issues for pre-8.3
users of tsearch.  This isn't meant to be permanent documentation,
but to call out the areas that need either fixing or real documentation.

18 years agoAdd a useless return statement to suppress a warning seen with some
Tom Lane [Mon, 22 Oct 2007 01:02:22 +0000 (01:02 +0000)]
Add a useless return statement to suppress a warning seen with some
versions of gcc (I'm seeing it with Apple's gcc 4.0.1).  I think the
reason we did not see this before was that the assert() macros in the
regex code were all no-ops till recently.

18 years agoFix shared tsvector/tsquery input code so that we don't say "syntax error in
Tom Lane [Sun, 21 Oct 2007 22:29:56 +0000 (22:29 +0000)]
Fix shared tsvector/tsquery input code so that we don't say "syntax error in
tsvector" when we are really parsing a tsquery.  Report the bogus input,
too.  Make styles of some related error messages more consistent.