- 30 Aug, 2012 2 commits
-
-
Tom Lane authored
In the initial cut at LATERAL, I kept the rule that cheapest_total_path was always unparameterized, which meant it had to be NULL if the relation has no unparameterized paths. It turns out to work much more nicely if we always have *some* path nominated as cheapest-total for each relation. In particular, let's still say it's the cheapest unparameterized path if there is one; if not, take the cheapest-total-cost path among those of the minimum available parameterization. (The first rule is actually a special case of the second.) This allows reversion of some temporary lobotomizations I'd put in place. In particular, the planner can now consider hash and merge joins for joins below a parameter-supplying nestloop, even if there aren't any unparameterized paths available. This should bring planning of LATERAL-containing queries to the same level as queries not using that feature. Along the way, simplify management of parameterized paths in add_path() and friends. In the original coding for parameterized paths in 9.2, I tried to minimize the logic changes in add_path(), so it just treated parameterization as yet another dimension of comparison for paths. We later made it ignore pathkeys (sort ordering) of parameterized paths, on the grounds that ordering isn't a useful property for the path on the inside of a nestloop, so we might as well get rid of useless parameterized paths as quickly as possible. But we didn't take that reasoning as far as we should have. Startup cost isn't a useful property inside a nestloop either, so add_path() ought to discount startup cost of parameterized paths as well. Having done that, the secondary sorting I'd implemented (in add_parameterized_path) is no longer needed --- any parameterized path that survives add_path() at all is worth considering at higher levels. So this should be a bit faster as well as simpler.
-
Bruce Momjian authored
-
- 29 Aug, 2012 4 commits
-
-
Bruce Momjian authored
reporting in contains invalid data.
-
Heikki Linnakangas authored
This includes two micro-optimizations to the tight inner loop in descending the SP-GiST tree: 1. avoid an extra function call to index_getprocinfo when calling user-defined choose function, and 2. avoid a useless palloc+pfree when node labels are not used.
-
Alvaro Herrera authored
Evidently I failed to test a compile after my earlier header shuffling.
-
Peter Eisentraut authored
-
- 28 Aug, 2012 14 commits
-
-
Alvaro Herrera authored
The heapam XLog functions are used by other modules, not all of which are interested in the rest of the heapam API. With this, we let them get just the XLog stuff in which they are interested and not pollute them with unrelated includes. Also, since heapam.h no longer requires xlog.h, many files that do include heapam.h no longer get xlog.h automatically, including a few headers. This is useful because heapam.h is getting pulled in by execnodes.h, which is in turn included by a lot of files.
-
Alvaro Herrera authored
Instead, place a forward struct declaration for struct catclist in syscache.h. This reduces header proliferation somewhat.
-
Alvaro Herrera authored
This lets files that are mere users of ResourceOwner not automatically include the headers for stuff that is managed by the resowner mechanism.
-
Alvaro Herrera authored
-
Tom Lane authored
Per Peter Geoghegan.
-
Tom Lane authored
Since we're not installing this file anymore, it has no reason to exist, other than as historical reference; but we have an SCM for that.
-
Bruce Momjian authored
percentage column before count column. Docs updated.
-
Bruce Momjian authored
has no space before it. Report by Erik Rijkers
-
Bruce Momjian authored
Lane's correction.
-
Alvaro Herrera authored
-
Peter Eisentraut authored
-
Bruce Momjian authored
David E. Wheeler
-
Tom Lane authored
Clarify the compatibility notes about EXTRACT() and about statistics timing columns.
-
Tom Lane authored
This is so that these sections will have stable HTML tags that one can link to, rather than things like "AEN1902". Perhaps we should mount a campaign to do this everywhere, but I've found myself pointing at syntax.sgml subsections often enough to be sure it's useful here.
-
- 27 Aug, 2012 10 commits
-
-
Bruce Momjian authored
pg_restore.
-
Alvaro Herrera authored
The previous signature made it very easy to pass something other than the printf-format specifier in the corresponding position, without any warning from the compiler. While at it, move some of the escaping, redirecting and quoting responsibilities from the callers into exec_prog() itself. This makes the callsites cleaner.
-
Alvaro Herrera authored
It was confusing symlinks with hard links.
-
Alvaro Herrera authored
-
Bruce Momjian authored
has been created by adding #include <stdlib.h> to parse.c. per request from Kevin Grittner.
-
Heikki Linnakangas authored
This enables selectivity estimation of the <<, >>, &<, &> and && operators, as well as the normal inequality operators: <, <=, >=, >. "range @> element" is also supported, but the range-variant @> and <@ operators are not, because they cannot be sensibly estimated with lower and upper bound histograms alone. We would need to make some assumption about the lengths of the ranges for that. Alexander's patch included a separate histogram of lengths for that, but I left that out of the patch for simplicity. Hopefully that will be added as a followup patch. The fraction of empty ranges is also calculated and used in estimation. Alexander Korotkov, heavily modified by me.
-
Peter Eisentraut authored
It still thought that the --xlog-method option argument could be empty, as in a previous version of this feature.
-
Bruce Momjian authored
Brad Davis
-
Tom Lane authored
This patch takes care of a number of problems having to do with failure to choose valid join orders and incorrect handling of lateral references pulled up from subqueries. Notable changes: * Add a LateralJoinInfo data structure similar to SpecialJoinInfo, to represent join ordering constraints created by lateral references. (I first considered extending the SpecialJoinInfo structure, but the semantics are different enough that a separate data structure seems better.) Extend join_is_legal() and related functions to prevent trying to form unworkable joins, and to ensure that we will consider joins that satisfy lateral references even if the joins would be clauseless. * Fill in the infrastructure needed for the last few types of relation scan paths to support parameterization. We'd have wanted this eventually anyway, but it is necessary now because a relation that gets pulled up out of a UNION ALL subquery may acquire a reltargetlist containing lateral references, meaning that its paths *have* to be parameterized whether or not we have any code that can push join quals down into the scan. * Compute data about lateral references early in query_planner(), and save in RelOptInfo nodes, to avoid repetitive calculations later. * Assorted corner-case bug fixes. There's probably still some bugs left, but this is a lot closer to being real than it was before.
-
- 26 Aug, 2012 2 commits
-
-
Bruce Momjian authored
for CREATE TABLE LIKE ... INCLUDING INDEXES. Per report from david.sahagian@emc.com
-
Bruce Momjian authored
-
- 25 Aug, 2012 4 commits
-
-
Bruce Momjian authored
the same as \copy.
-
Bruce Momjian authored
ISO "T" timestamptz format.
-
Peter Eisentraut authored
-
Peter Eisentraut authored
-
- 24 Aug, 2012 3 commits
-
-
Tom Lane authored
The GUC check hooks for transaction_read_only and transaction_isolation tried to check RecoveryInProgress(), so as to disallow setting read/write mode or serializable isolation level (respectively) in hot standby sessions. However, GUC check hooks can be called in many situations where we're not connected to shared memory at all, resulting in a crash in RecoveryInProgress(). Among other cases, this results in EXEC_BACKEND builds crashing during child process start if default_transaction_isolation is serializable, as reported by Heikki Linnakangas. Protect those calls by silently allowing any setting when not inside a transaction; which is okay anyway since these GUCs are always reset at start of transaction. Also, add a check to GetSerializableTransactionSnapshot() to complain if we are in hot standby. We need that check despite the one in check_XactIsoLevel() because default_transaction_isolation could be serializable. We don't want to complain any sooner than this in such cases, since that would prevent running transactions at all in such a state; but a transaction can be run, if SET TRANSACTION ISOLATION is done before setting a snapshot. Per report some months ago from Robert Haas. Back-patch to 9.1, since these problems were introduced by the SSI patch. Kevin Grittner and Tom Lane, with ideas from Heikki Linnakangas
-
Peter Eisentraut authored
-
Peter Eisentraut authored
When an invalid query parameter is reported, some memory leaks. found by Coverity
-
- 23 Aug, 2012 1 commit
-
-
Tom Lane authored
If we revoke a grant option from some role X, but X still holds the option via another grant, we should not recursively revoke the privilege from role(s) Y that X had granted it to. This was supposedly fixed as one aspect of commit 4b2dafcc, but I must not have tested it, because in fact that code never worked: it forgot to shift the grant-option bits back over when masking the bits being revoked. Per bug #6728 from Daniel German. Back-patch to all active branches, since this has been wrong since 8.0.
-