summaryrefslogtreecommitdiff
path: root/src
AgeCommit message (Collapse)Author
2010-01-02Add missing schema-qualification in tab completion query.Tom Lane
2010-01-02Fix similar_escape() to convert parentheses to non-capturing style.Tom Lane
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.
2010-01-02check_exclusion_constraint didn't actually work correctly for indexTom Lane
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.
2010-01-02Update copyright for the year 2010.Bruce Momjian
2010-01-02Silence compiler warning about size of size_t being larger than the resultMagnus Hagander
variable it's stored in. We know this can never happen. Per discussion.
2010-01-02Set proper sizes for size_t and void* on 64-bit Windows builds.Magnus Hagander
Tsutomu Yamada
2010-01-02Support 64-bit shared memory when building on 64-bit Windows.Magnus Hagander
Tsutomu Yamada
2010-01-02Fix one more cast for _open_osfhandle().Magnus Hagander
Tsutomu Yamada
2010-01-02Fix cast for _open_osfhandle().Magnus Hagander
Tsutomu Yamada
2010-01-01Add an "argisrow" field to NullTest nodes, following a plan made way back inTom Lane
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.
2010-01-01Support "x IS NOT NULL" clauses as indexscan conditions. This turns outTom Lane
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.
2010-01-01Silence compiler warning on 64-bit windows buildMagnus Hagander
2010-01-01Detect a 64-bit build environment on Windows, and generate the appropriateMagnus Hagander
project files. Based on the work of Tsutomu Yamada, but much refactored.
2010-01-01Delete solution cache file on clean, if it exists.Magnus Hagander
2010-01-01Update SQL features supported listPeter Eisentraut
2010-01-01Make the win32 putenv() override update *all* present versions of theMagnus Hagander
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
2009-12-31Suppress compiler warning, per buildfarm member narwhalTom Lane
2009-12-31Suppress compiler warning (pid_t isn't int everywhere)Tom Lane
2009-12-31Add missing 'static' tag.Tom Lane
2009-12-31Redefine Datum as uintptr_t, instead of unsigned long.Tom Lane
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
2009-12-31Update SQL features list for aggregate ORDER BY supportPeter Eisentraut
2009-12-31Add information_schema.triggered_update_columnsPeter Eisentraut
This reflects the recently added support for triggers on columns.
2009-12-31enable examples to compile on Windows. patch from Hiroshi Saito.Andrew Dunstan
2009-12-30Fill in information schema column for trigger WHEN conditionPeter Eisentraut
2009-12-30Dept of second thoughts: recursive case in ANALYZE shouldn't emit aTom Lane
pgstats message. This might need to be done differently later, but with the current logic that's what should happen.
2009-12-30Revise pgstat's tracking of tuple changes to improve the reliability ofTom Lane
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.
2009-12-30Update SQL conformance: search conditions on triggers are supportedPeter Eisentraut
2009-12-30Exclude part of the product name string that is localized in Japanese versionsMagnus Hagander
of MSVC when detecting MSVC version. Hiroshi Inoue
2009-12-30Reset minRecoveryPoint at checkpoints, so that we don't uselessly updateHeikki Linnakangas
it in the control file at crash recovery following an archive recovery. Per Fujii Masao and subsequent discussion.
2009-12-30Set errno to zero before invoking SSL_read or SSL_write. It appears thatTom Lane
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.
2009-12-30Reject invalid input in int2vectorin.Robert Haas
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
2009-12-29Add an index on pg_inherits.inhparent, and use it to avoid seqscans inTom Lane
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.
2009-12-29Add the ability to store inheritance-tree statistics in pg_statistic,Tom Lane
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.
2009-12-29Previous fix for temporary file management broke returning a set fromHeikki Linnakangas
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.
2009-12-28Remove PGDLLIMPORT used for binary upgrade; must be on the externs, per Tom.Bruce Momjian
2009-12-28Add PGDLLIMPORT for binary_upgrade global variables so shared objectBruce Momjian
libraries can access them.
2009-12-28Remove non-ascii characters from source code.Bruce Momjian
2009-12-27Avoid memory leak if pgstat_vacuum_stat is interrupted partway through.Tom Lane
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.
2009-12-27Remove a couple of unnecessary calls of CreateCacheMemoryContext. TheseTom Lane
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.
2009-12-27Remove now unreferenced variable.Magnus Hagander
2009-12-27If the MSVCRT module is not found in the current binary, proceed to updateMagnus Hagander
system and local environments anyway, instead of aborting. (This will happen in a MSVC build with no or very few external libraries linked in)
2009-12-27Add backend and pg_dump code to allow preservation of pg_enum oids, forBruce Momjian
use in binary upgrades. Bump catalog version for detection by pg_migrator of new backend API.
2009-12-26Zero-label enums:Bruce Momjian
Allow enums to be created with zero labels, for use during binary upgrade.
2009-12-25Fix brain fade in join-removal patch: a pushed-down clause in the outer join'sTom Lane
restrict list is not just something to ignore, it's actually grounds to abandon the optimization entirely. Per bug #5255 from Matteo Beccati.
2009-12-25Upgrade to latest ppport.h. Patch from Tim Bunce.Andrew Dunstan
2009-12-24Rename EnumValuesCreate() single-letter variable names to usefulBruce Momjian
variable names.
2009-12-24Binary upgrade:Bruce Momjian
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.
2009-12-24Fix wrong WAL info value generated when gistContinueInsert() performs anTom Lane
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
2009-12-23Allow the index name to be omitted in CREATE INDEX, causing the system toTom Lane
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.
2009-12-23Remove code that attempted to rename index columns to keep them in sync withTom Lane
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.