- 20 Nov, 2005 3 commits
- 
- 
Tom Lane authored
- 
Tom Lane authoredthe convenience of tuptoaster.c and is no longer needed, so may as well get rid of some small amount of overhead. 
- 
Tom Lane authoredtuple in-place, but instead passes back an all-new tuple structure if any changes are needed. This is a much cleaner and more robust solution for the bug discovered by Alexey Beschiokov; accordingly, revert the quick hack I installed yesterday. With this change, HeapTupleData.t_datamcxt is no longer needed; will remove it in a separate commit in HEAD only. 
 
- 
- 19 Nov, 2005 6 commits
- 
- 
Tom Lane authoreddoing heap_insert or heap_update, wipe out any extracted fields in the TupleTableSlot containing the tuple, because they might not be valid anymore if tuptoaster.c changed the tuple. Safe because slot must be in the materialized state, but mighty ugly --- find a better answer! 
- 
Tom Lane authorednot only the array contents, before claiming two arrays are equal. Per recent discussion. 
- 
Andrew Dunstan authoredDROP objecttype IF EXISTS for the following objects: table view index sequence schema type domain conversion 
- 
Tom Lane authoredmore tests than strictly necessary, but did not feel like tracing call paths in detail ... 
- 
Tom Lane authoredbe useful to actually do something with nulls, rather than reject them, but I'll just close the hole for now. 
- 
Tom Lane authoredthe array (for array_push) or higher-dimensional array (for array_cat) rather than decrementing it as before. This avoids generating lower bounds other than one for any array operation within the SQL spec. Per recent discussion. Interestingly, this seems to have been the original behavior, because while updating the docs I noticed that a large fraction of relevant examples were *wrong* for the old behavior and are now right. Is it worth correcting this in the back-branch docs? 
 
- 
- 18 Nov, 2005 6 commits
- 
- 
Tom Lane authoredrecursed twice on its first argument, leading to exponential time spent on a deep nest of COALESCEs ... such as a deeply nested FULL JOIN would produce. Per report from Matt Carter. 
- 
Andrew Dunstan authoredtranslate undef to NULL for result arrayref, now that we allow NULLs in arrays. Update plperl regression test accordingly. 
- 
Alvaro Herrera authored
- 
Neil Conway authored
- 
Tom Lane authoredcontents directly. 
- 
Bruce Momjian authoredJ.Kuwamura 
 
- 
- 17 Nov, 2005 3 commits
- 
- 
Andrew Dunstan authoredmake psql honor explicit database parameter in -l mode, in case "postgres" database is missing - per complaint from Philip Yarra. 
- 
Tom Lane authoredfunctionality, but I still need to make another pass looking at places that incidentally use arrays (such as ACL manipulation) to make sure they are null-safe. Contrib needs work too. I have not changed the behaviors that are still under discussion about array comparison and what to do with lower bounds. 
- 
Tom Lane authoredthat was added to localbuf.c in 8.1; therefore, applying it to a temp table left corrupt lookup state in memory. The only case where this had a significant chance of causing problems was an ON COMMIT DELETE ROWS temp table; the other possible paths left bogus state that was unlikely to be used again. Per report from Csaba Nagy. 
 
- 
- 16 Nov, 2005 7 commits
- 
- 
Bruce Momjian authored< so duplicate checking can be easily performed. > so duplicate checking can be easily performed. It is possible to > do it without a unique index if we require the user to LOCK the table > before the MERGE. 
- 
Tom Lane authoredits result when the clause was an OR clause. Brain fade exposed by example from Sebastian BÎck. 
- 
Bruce Momjian authored< * Add a libpq function to support Parse/DescribeStatement capability < * Add PQescapeIdentifier() to libpq < * Prevent PQfnumber() from lowercasing unquoted the column name < < PQfnumber() should never have been doing lowercasing, but historically < it has so we need a way to prevent it < 648a642,661 > > > libpq > > o Add a function to support Parse/DescribeStatement capability > o Add PQescapeIdentifier() > o Prevent PQfnumber() from lowercasing unquoted the column name > > PQfnumber() should never have been doing lowercasing, but > historically it has so we need a way to prevent it > > o Allow query results to be automatically batched to the client > > Currently, all query results are transfered to the libpq > client before libpq makes the results available to the > application. This feature would allow the application to make > use of the first result rows while the rest are transfered, or > held on the server waiting for them to be requested by libpq. > One complexity is that a query like SELECT 1/col could error > out mid-way through the result set. 
- 
Tatsuo Ishii authored
- 
Bruce Momjian authored
- 
Bruce Momjian authored
- 
Bruce Momjian authored
 
- 
- 15 Nov, 2005 4 commits
- 
- 
Bruce Momjian authored> > To implement this cleanly requires that the table have a unique index > so duplicate checking can be easily performed. > 
- 
Bruce Momjian authoredfeatures. 
- 
Bruce Momjian authorednames from being added to pgindent's typedef list. The existance of them caused weird formatting in the date/type files, and in keywords.c. Backpatch to 8.1.X. 
- 
Bruce Momjian authoredcolumns, shifting comment to the right when more than 150 'else if' clauses were used, and update typedefs for 8.1.X. NetBSD patched updated, with documentation. 
 
- 
- 14 Nov, 2005 7 commits
- 
- 
Tom Lane authoredsense and rename to "outerjoin_delayed" to more clearly reflect what it means). I had decided that it was redundant in 8.1, but the folly of this is exposed by a bug report from Sebastian Böck. The place where it's needed is to prevent orindxpath.c from cherry-picking arms of an outer-join OR clause to form a relation restriction that isn't actually legal to push down to the relation scan level. There may be some legal cases that this forbids optimizing, but we'd need much closer analysis to determine it. 
- 
Alvaro Herrera authored
- 
Bruce Momjian authoredCosmetic fix only. 
- 
Tom Lane authoredslot of the topmost plan node when a trigger returns a modified tuple. These appear to be the only places where a plan node's caller did not treat the result slot as read-only, which is an assumption that nodeUnique makes as of 8.1. Fixes trigger-vs-DISTINCT bug reported by Frank van Vugt. 
- 
Teodor Sigaev authoredof self-defined macros, add limit of Array to gist__int_ops. BTW, intarray now doesn't support NULLs in arrays. 
- 
Teodor Sigaev authoredUse postgres-wide macros BITS_PER_BYTE instead self-definenig macros, also use it for calculating bit length of TPQTGist 
- 
Teodor Sigaev authored
 
- 
- 13 Nov, 2005 2 commits
- 
- 
Tom Lane authoredsurprising results when it's some other numeric type. This doesn't solve the generic problem of surprising implicit casts to text, but it's a low-impact way of making sure this particular case behaves sanely. Per gripe from Harald Fuchs and subsequent discussion. 
- 
Bruce Momjian authoredindent bug. 
 
- 
- 10 Nov, 2005 2 commits
- 
- 
Andrew Dunstan authoredadd missing quote mark to ident_file sample line - per Hiroshi Saito 
- 
Tom Lane authoredanything but transaction-exiting commands (ROLLBACK etc). We already rejected Parse and Execute in such cases, so there seems little point in allowing Bind. This prevents at least an Assert failure, and probably worse things, since there's a lot of infrastructure that doesn't work when not in a live transaction. We can also simplify the Bind logic a bit by rejecting messages with a nonzero number of parameters, instead of the former kluge to silently substitute NULL for each parameter. Per bug #2033 from Joel Stevenson. 
 
-